:root {
    --theme-background: #05080d;
    --theme-background-soft: #0b1118;
    --theme-surface: #111820;
    --theme-surface-raised: #151f29;
    --theme-surface-border: #26313d;
    --theme-text: #f5f7fa;
    --theme-muted: #9aa4af;
    --theme-accent: #f5b800;
    --theme-accent-strong: #ffcc00;
    --theme-header-bg: rgb(5 8 13 / 94%);
    --theme-header-border: rgb(245 184 0 / 55%);
    --theme-page-gradient: linear-gradient(180deg, rgb(5 8 13 / 98%), rgb(6 11 16 / 100%) 36%, rgb(5 8 13 / 100%));
    --theme-page-texture: linear-gradient(transparent, transparent);
    --theme-page-image: linear-gradient(transparent, transparent);
    --theme-page-image-opacity: 0;
    --theme-page-effect: linear-gradient(transparent, transparent);
    --theme-page-effect-opacity: 0;
    --theme-hero-overlay:
        linear-gradient(90deg, rgb(5 8 13 / 96%) 0%, rgb(5 8 13 / 74%) 36%, rgb(5 8 13 / 18%) 74%, rgb(5 8 13 / 76%) 100%),
        linear-gradient(0deg, rgb(5 8 13 / 96%) 0%, rgb(5 8 13 / 28%) 54%, rgb(5 8 13 / 10%) 100%);
    --theme-hero-pattern: linear-gradient(transparent, transparent);
    --theme-hero-glow: linear-gradient(transparent, transparent);
    --color-bg: var(--theme-background);
    --color-bg-soft: var(--theme-background-soft);
    --color-surface: var(--theme-surface);
    --color-surface-raised: var(--theme-surface-raised);
    --color-surface-border: var(--theme-surface-border);
    --color-text: var(--theme-text);
    --color-muted: var(--theme-muted);
    --color-accent: var(--theme-accent);
    --color-accent-strong: var(--theme-accent-strong);
    --color-danger: #ef4444;
    --color-success: #22c55e;
    --shadow-panel: 0 20px 50px rgb(0 0 0 / 34%);
    --site-width: 1320px;
}

.theme-halloween {
    --theme-background: #13091f;
    --theme-background-soft: #1a0d29;
    --theme-surface: #171021;
    --theme-surface-raised: #21142d;
    --theme-surface-border: #3e2a4f;
    --theme-accent: #ff7a00;
    --theme-accent-strong: #ffb000;
    --theme-header-bg: rgb(19 9 31 / 94%);
    --theme-header-border: rgb(255 122 0 / 60%);
    --theme-page-gradient: linear-gradient(180deg, rgb(19 9 31 / 98%), rgb(10 8 18 / 100%) 44%, rgb(5 8 13 / 100%));
    --theme-page-texture: repeating-linear-gradient(116deg, rgb(255 122 0 / 5%) 0 1px, transparent 1px 22px), repeating-linear-gradient(64deg, rgb(156 65 255 / 5%) 0 1px, transparent 1px 28px);
    --theme-page-effect: linear-gradient(110deg, transparent 0%, rgb(255 122 0 / 12%) 42%, transparent 68%), linear-gradient(250deg, transparent 8%, rgb(95 36 149 / 18%) 50%, transparent 78%);
    --theme-page-effect-opacity: 0.55;
    --theme-hero-overlay:
        linear-gradient(90deg, rgb(19 9 31 / 96%) 0%, rgb(19 9 31 / 76%) 38%, rgb(19 9 31 / 20%) 74%, rgb(19 9 31 / 82%) 100%),
        linear-gradient(0deg, rgb(19 9 31 / 96%) 0%, rgb(19 9 31 / 30%) 54%, rgb(19 9 31 / 12%) 100%);
    --theme-hero-pattern: repeating-linear-gradient(135deg, rgb(255 122 0 / 12%) 0 2px, transparent 2px 34px), repeating-linear-gradient(45deg, rgb(93 48 150 / 10%) 0 1px, transparent 1px 26px);
    --theme-hero-glow: linear-gradient(120deg, transparent 0%, rgb(255 122 0 / 16%) 48%, transparent 78%);
}

.theme-christmas {
    --theme-background: #07140f;
    --theme-background-soft: #0d2017;
    --theme-surface: #10231a;
    --theme-surface-raised: #172d22;
    --theme-surface-border: #2c4b3d;
    --theme-accent: #d92d20;
    --theme-accent-strong: #f5c542;
    --theme-header-bg: rgb(7 20 15 / 94%);
    --theme-header-border: rgb(217 45 32 / 60%);
    --theme-page-gradient: linear-gradient(180deg, rgb(7 20 15 / 98%), rgb(9 31 23 / 100%) 38%, rgb(5 8 13 / 100%));
    --theme-page-texture: repeating-radial-gradient(circle at 0 0, rgb(245 197 66 / 18%) 0 1px, transparent 1px 32px), repeating-linear-gradient(90deg, rgb(217 45 32 / 5%) 0 1px, transparent 1px 42px);
    --theme-page-effect: linear-gradient(120deg, transparent 0%, rgb(245 197 66 / 12%) 48%, transparent 76%), linear-gradient(250deg, transparent 0%, rgb(217 45 32 / 12%) 52%, transparent 86%);
    --theme-page-effect-opacity: 0.5;
    --theme-hero-pattern: repeating-radial-gradient(circle at 0 0, rgb(245 197 66 / 20%) 0 1px, transparent 1px 28px), repeating-linear-gradient(135deg, rgb(217 45 32 / 10%) 0 2px, transparent 2px 34px);
    --theme-hero-glow: linear-gradient(115deg, transparent 0%, rgb(245 197 66 / 16%) 46%, transparent 78%);
}

.theme-winter {
    --theme-background: #07111c;
    --theme-background-soft: #0b1b2a;
    --theme-surface: #102033;
    --theme-surface-raised: #142840;
    --theme-surface-border: #2d4d68;
    --theme-accent: #8fd8ff;
    --theme-accent-strong: #c6f1ff;
    --theme-header-bg: rgb(7 17 28 / 94%);
    --theme-header-border: rgb(143 216 255 / 60%);
    --theme-page-gradient: linear-gradient(180deg, rgb(7 17 28 / 98%), rgb(8 24 39 / 100%) 40%, rgb(5 8 13 / 100%));
    --theme-page-texture: repeating-radial-gradient(circle at 0 0, rgb(198 241 255 / 18%) 0 1px, transparent 1px 30px), repeating-linear-gradient(135deg, rgb(143 216 255 / 5%) 0 1px, transparent 1px 22px);
    --theme-page-effect: linear-gradient(120deg, transparent 0%, rgb(143 216 255 / 14%) 48%, transparent 78%), linear-gradient(250deg, transparent 4%, rgb(45 77 104 / 20%) 55%, transparent 86%);
    --theme-page-effect-opacity: 0.55;
    --theme-hero-pattern: repeating-radial-gradient(circle at 0 0, rgb(198 241 255 / 20%) 0 1px, transparent 1px 26px), repeating-linear-gradient(45deg, rgb(143 216 255 / 8%) 0 1px, transparent 1px 22px);
    --theme-hero-glow: linear-gradient(118deg, transparent 0%, rgb(143 216 255 / 18%) 48%, transparent 82%);
}

.theme-spring {
    --theme-background: #07140d;
    --theme-background-soft: #0d2216;
    --theme-surface: #11291a;
    --theme-surface-raised: #193721;
    --theme-surface-border: #315a3a;
    --theme-accent: #86efac;
    --theme-accent-strong: #f9a8d4;
    --theme-header-bg: rgb(7 20 13 / 94%);
    --theme-header-border: rgb(134 239 172 / 62%);
    --theme-page-gradient: linear-gradient(180deg, rgb(7 20 13 / 98%), rgb(12 35 20 / 100%) 40%, rgb(5 8 13 / 100%));
    --theme-page-texture: repeating-radial-gradient(circle at 0 0, rgb(249 168 212 / 14%) 0 1px, transparent 1px 36px), repeating-linear-gradient(120deg, rgb(134 239 172 / 5%) 0 2px, transparent 2px 30px);
    --theme-page-effect: linear-gradient(125deg, transparent 0%, rgb(134 239 172 / 13%) 46%, transparent 78%), linear-gradient(245deg, transparent 8%, rgb(249 168 212 / 10%) 54%, transparent 84%);
    --theme-page-effect-opacity: 0.5;
    --theme-hero-overlay:
        linear-gradient(90deg, rgb(7 20 13 / 96%) 0%, rgb(7 20 13 / 76%) 38%, rgb(7 20 13 / 20%) 74%, rgb(7 20 13 / 82%) 100%),
        linear-gradient(0deg, rgb(7 20 13 / 96%) 0%, rgb(7 20 13 / 30%) 54%, rgb(7 20 13 / 12%) 100%);
    --theme-hero-pattern: repeating-radial-gradient(circle at 0 0, rgb(249 168 212 / 16%) 0 2px, transparent 2px 34px), repeating-linear-gradient(130deg, rgb(134 239 172 / 11%) 0 2px, transparent 2px 30px);
    --theme-hero-glow: linear-gradient(120deg, transparent 0%, rgb(134 239 172 / 16%) 46%, transparent 78%);
}

.theme-summer {
    --theme-background: #061111;
    --theme-background-soft: #0b1d1d;
    --theme-surface: #102623;
    --theme-surface-raised: #142f2d;
    --theme-surface-border: #2b514d;
    --theme-accent: #facc15;
    --theme-accent-strong: #ffe45c;
    --theme-header-bg: rgb(6 17 17 / 94%);
    --theme-header-border: rgb(250 204 21 / 60%);
    --theme-page-texture: repeating-linear-gradient(118deg, rgb(250 204 21 / 6%) 0 2px, transparent 2px 38px), repeating-linear-gradient(62deg, rgb(34 197 94 / 4%) 0 1px, transparent 1px 32px);
    --theme-page-effect: linear-gradient(112deg, transparent 0%, rgb(250 204 21 / 12%) 42%, transparent 72%), linear-gradient(245deg, transparent 6%, rgb(20 184 166 / 12%) 54%, transparent 86%);
    --theme-page-effect-opacity: 0.48;
    --theme-hero-pattern: repeating-linear-gradient(128deg, rgb(250 204 21 / 14%) 0 3px, transparent 3px 42px), repeating-linear-gradient(52deg, rgb(20 184 166 / 9%) 0 2px, transparent 2px 34px);
    --theme-hero-glow: linear-gradient(115deg, transparent 0%, rgb(250 204 21 / 18%) 45%, transparent 80%);
}

.theme-autumn {
    --theme-background: #120c07;
    --theme-background-soft: #21150b;
    --theme-surface: #24170f;
    --theme-surface-raised: #321f13;
    --theme-surface-border: #5b3a25;
    --theme-accent: #f59e0b;
    --theme-accent-strong: #ef4444;
    --theme-header-bg: rgb(18 12 7 / 94%);
    --theme-header-border: rgb(245 158 11 / 64%);
    --theme-page-gradient: linear-gradient(180deg, rgb(18 12 7 / 98%), rgb(32 19 10 / 100%) 40%, rgb(5 8 13 / 100%));
    --theme-page-texture: repeating-linear-gradient(122deg, rgb(245 158 11 / 7%) 0 2px, transparent 2px 28px), repeating-linear-gradient(64deg, rgb(239 68 68 / 5%) 0 1px, transparent 1px 36px);
    --theme-page-effect: linear-gradient(118deg, transparent 0%, rgb(245 158 11 / 13%) 48%, transparent 76%), linear-gradient(250deg, transparent 8%, rgb(127 29 29 / 18%) 55%, transparent 84%);
    --theme-page-effect-opacity: 0.52;
    --theme-hero-overlay:
        linear-gradient(90deg, rgb(18 12 7 / 96%) 0%, rgb(18 12 7 / 76%) 38%, rgb(18 12 7 / 20%) 74%, rgb(18 12 7 / 82%) 100%),
        linear-gradient(0deg, rgb(18 12 7 / 96%) 0%, rgb(18 12 7 / 30%) 54%, rgb(18 12 7 / 12%) 100%);
    --theme-hero-pattern: repeating-linear-gradient(136deg, rgb(245 158 11 / 14%) 0 3px, transparent 3px 36px), repeating-linear-gradient(48deg, rgb(239 68 68 / 9%) 0 2px, transparent 2px 30px);
    --theme-hero-glow: linear-gradient(115deg, transparent 0%, rgb(245 158 11 / 17%) 46%, transparent 80%);
}

.theme-black-friday {
    --theme-background: #050505;
    --theme-background-soft: #0b0b0b;
    --theme-surface: #111111;
    --theme-surface-raised: #1b1b1b;
    --theme-surface-border: #343434;
    --theme-accent: #f5b800;
    --theme-accent-strong: #ffef8a;
    --theme-header-bg: rgb(5 5 5 / 96%);
    --theme-header-border: rgb(245 184 0 / 70%);
    --theme-page-texture: repeating-linear-gradient(115deg, rgb(255 255 255 / 6%) 0 1px, transparent 1px 24px), repeating-linear-gradient(65deg, rgb(245 184 0 / 5%) 0 2px, transparent 2px 38px);
    --theme-page-effect: linear-gradient(118deg, transparent 0%, rgb(245 184 0 / 13%) 48%, transparent 76%), linear-gradient(250deg, transparent 6%, rgb(255 255 255 / 8%) 54%, transparent 84%);
    --theme-page-effect-opacity: 0.5;
    --theme-hero-pattern: repeating-linear-gradient(135deg, rgb(245 184 0 / 16%) 0 2px, transparent 2px 28px), repeating-linear-gradient(45deg, rgb(255 255 255 / 8%) 0 1px, transparent 1px 22px);
    --theme-hero-glow: linear-gradient(116deg, transparent 0%, rgb(245 184 0 / 18%) 46%, transparent 80%);
}

.theme-easter {
    --theme-background: #09121f;
    --theme-background-soft: #101b2d;
    --theme-surface: #132234;
    --theme-surface-raised: #1b2c41;
    --theme-surface-border: #34485f;
    --theme-accent: #f7d774;
    --theme-accent-strong: #f9a8d4;
    --theme-header-bg: rgb(9 18 31 / 94%);
    --theme-header-border: rgb(247 215 116 / 62%);
    --theme-page-gradient: linear-gradient(180deg, rgb(9 18 31 / 98%), rgb(15 26 43 / 100%) 42%, rgb(5 8 13 / 100%));
    --theme-page-texture: repeating-radial-gradient(circle at 0 0, rgb(247 215 116 / 18%) 0 2px, transparent 2px 34px), repeating-radial-gradient(circle at 18px 18px, rgb(249 168 212 / 12%) 0 1px, transparent 1px 36px);
    --theme-page-effect: linear-gradient(124deg, transparent 0%, rgb(247 215 116 / 12%) 48%, transparent 78%), linear-gradient(246deg, transparent 8%, rgb(249 168 212 / 10%) 54%, transparent 86%);
    --theme-page-effect-opacity: 0.5;
    --theme-hero-overlay:
        linear-gradient(90deg, rgb(9 18 31 / 96%) 0%, rgb(9 18 31 / 76%) 38%, rgb(9 18 31 / 20%) 74%, rgb(9 18 31 / 82%) 100%),
        linear-gradient(0deg, rgb(9 18 31 / 96%) 0%, rgb(9 18 31 / 30%) 54%, rgb(9 18 31 / 12%) 100%);
    --theme-hero-pattern: repeating-radial-gradient(circle at 0 0, rgb(247 215 116 / 18%) 0 2px, transparent 2px 30px), repeating-radial-gradient(circle at 16px 16px, rgb(249 168 212 / 12%) 0 1px, transparent 1px 32px);
    --theme-hero-glow: linear-gradient(120deg, transparent 0%, rgb(247 215 116 / 16%) 48%, transparent 78%);
}

.theme-valborg {
    --theme-background: #130b08;
    --theme-background-soft: #21100b;
    --theme-surface: #24140f;
    --theme-surface-raised: #321b13;
    --theme-surface-border: #5b3425;
    --theme-accent: #ff8a3d;
    --theme-accent-strong: #ffd166;
    --theme-header-bg: rgb(19 11 8 / 94%);
    --theme-header-border: rgb(255 138 61 / 64%);
    --theme-page-gradient: linear-gradient(180deg, rgb(19 11 8 / 98%), rgb(30 15 10 / 100%) 40%, rgb(5 8 13 / 100%));
    --theme-page-texture: repeating-linear-gradient(110deg, rgb(255 138 61 / 8%) 0 2px, transparent 2px 34px), repeating-linear-gradient(70deg, rgb(255 209 102 / 5%) 0 1px, transparent 1px 26px);
    --theme-page-effect: linear-gradient(116deg, transparent 0%, rgb(255 138 61 / 15%) 44%, transparent 76%), linear-gradient(250deg, transparent 6%, rgb(127 29 29 / 16%) 54%, transparent 84%);
    --theme-page-effect-opacity: 0.56;
    --theme-hero-overlay:
        linear-gradient(90deg, rgb(19 11 8 / 96%) 0%, rgb(19 11 8 / 76%) 38%, rgb(19 11 8 / 20%) 74%, rgb(19 11 8 / 82%) 100%),
        linear-gradient(0deg, rgb(19 11 8 / 96%) 0%, rgb(19 11 8 / 30%) 54%, rgb(19 11 8 / 12%) 100%);
    --theme-hero-pattern: repeating-linear-gradient(125deg, rgb(255 138 61 / 18%) 0 3px, transparent 3px 38px), repeating-linear-gradient(55deg, rgb(255 209 102 / 10%) 0 2px, transparent 2px 30px);
    --theme-hero-glow: linear-gradient(112deg, transparent 0%, rgb(255 138 61 / 20%) 44%, transparent 78%);
}

.theme-national-day {
    --theme-background: #06111f;
    --theme-background-soft: #0b1b33;
    --theme-surface: #10243d;
    --theme-surface-raised: #152f4f;
    --theme-surface-border: #2e5c8c;
    --theme-accent: #ffd83d;
    --theme-accent-strong: #5eb7ff;
    --theme-header-bg: rgb(6 17 31 / 94%);
    --theme-header-border: rgb(255 216 61 / 64%);
    --theme-page-gradient: linear-gradient(180deg, rgb(6 17 31 / 98%), rgb(9 30 56 / 100%) 40%, rgb(5 8 13 / 100%));
    --theme-page-texture: repeating-linear-gradient(90deg, rgb(255 216 61 / 7%) 0 2px, transparent 2px 34px), repeating-linear-gradient(0deg, rgb(94 183 255 / 6%) 0 2px, transparent 2px 40px);
    --theme-page-effect: linear-gradient(120deg, transparent 0%, rgb(255 216 61 / 12%) 48%, transparent 78%), linear-gradient(250deg, transparent 6%, rgb(94 183 255 / 14%) 55%, transparent 84%);
    --theme-page-effect-opacity: 0.52;
    --theme-hero-overlay:
        linear-gradient(90deg, rgb(6 17 31 / 96%) 0%, rgb(6 17 31 / 76%) 38%, rgb(6 17 31 / 20%) 74%, rgb(6 17 31 / 82%) 100%),
        linear-gradient(0deg, rgb(6 17 31 / 96%) 0%, rgb(6 17 31 / 30%) 54%, rgb(6 17 31 / 12%) 100%);
    --theme-hero-pattern: repeating-linear-gradient(90deg, rgb(255 216 61 / 14%) 0 3px, transparent 3px 42px), repeating-linear-gradient(0deg, rgb(94 183 255 / 10%) 0 2px, transparent 2px 36px);
    --theme-hero-glow: linear-gradient(118deg, transparent 0%, rgb(255 216 61 / 16%) 46%, transparent 80%);
}

.theme-midsummer {
    --theme-background: #07130c;
    --theme-background-soft: #0d2215;
    --theme-surface: #132a1b;
    --theme-surface-raised: #193821;
    --theme-surface-border: #315b3c;
    --theme-accent: #7ddf64;
    --theme-accent-strong: #fff176;
    --theme-header-bg: rgb(7 19 12 / 94%);
    --theme-header-border: rgb(125 223 100 / 62%);
    --theme-page-gradient: linear-gradient(180deg, rgb(7 19 12 / 98%), rgb(13 35 20 / 100%) 40%, rgb(5 8 13 / 100%));
    --theme-page-texture: repeating-linear-gradient(122deg, rgb(125 223 100 / 7%) 0 2px, transparent 2px 34px), repeating-radial-gradient(circle at 0 0, rgb(255 241 118 / 12%) 0 1px, transparent 1px 36px);
    --theme-page-effect: linear-gradient(120deg, transparent 0%, rgb(125 223 100 / 13%) 48%, transparent 78%), linear-gradient(250deg, transparent 8%, rgb(255 241 118 / 10%) 54%, transparent 86%);
    --theme-page-effect-opacity: 0.5;
    --theme-hero-overlay:
        linear-gradient(90deg, rgb(7 19 12 / 96%) 0%, rgb(7 19 12 / 76%) 38%, rgb(7 19 12 / 20%) 74%, rgb(7 19 12 / 82%) 100%),
        linear-gradient(0deg, rgb(7 19 12 / 96%) 0%, rgb(7 19 12 / 30%) 54%, rgb(7 19 12 / 12%) 100%);
    --theme-hero-pattern: repeating-linear-gradient(132deg, rgb(125 223 100 / 14%) 0 3px, transparent 3px 36px), repeating-radial-gradient(circle at 0 0, rgb(255 241 118 / 14%) 0 1px, transparent 1px 30px);
    --theme-hero-glow: linear-gradient(116deg, transparent 0%, rgb(125 223 100 / 17%) 48%, transparent 80%);
}

.theme-crayfish-party {
    --theme-background: #07121a;
    --theme-background-soft: #0c202b;
    --theme-surface: #112937;
    --theme-surface-raised: #153649;
    --theme-surface-border: #2f5d70;
    --theme-accent: #ff4d3d;
    --theme-accent-strong: #facc15;
    --theme-header-bg: rgb(7 18 26 / 94%);
    --theme-header-border: rgb(255 77 61 / 64%);
    --theme-page-gradient: linear-gradient(180deg, rgb(7 18 26 / 98%), rgb(10 33 45 / 100%) 40%, rgb(5 8 13 / 100%));
    --theme-page-texture: repeating-radial-gradient(circle at 0 0, rgb(250 204 21 / 14%) 0 1px, transparent 1px 38px), repeating-linear-gradient(118deg, rgb(255 77 61 / 6%) 0 2px, transparent 2px 32px);
    --theme-page-effect: linear-gradient(118deg, transparent 0%, rgb(255 77 61 / 13%) 46%, transparent 78%), linear-gradient(250deg, transparent 8%, rgb(250 204 21 / 10%) 54%, transparent 86%);
    --theme-page-effect-opacity: 0.52;
    --theme-hero-overlay:
        linear-gradient(90deg, rgb(7 18 26 / 96%) 0%, rgb(7 18 26 / 76%) 38%, rgb(7 18 26 / 20%) 74%, rgb(7 18 26 / 82%) 100%),
        linear-gradient(0deg, rgb(7 18 26 / 96%) 0%, rgb(7 18 26 / 30%) 54%, rgb(7 18 26 / 12%) 100%);
    --theme-hero-pattern: repeating-radial-gradient(circle at 0 0, rgb(250 204 21 / 18%) 0 2px, transparent 2px 34px), repeating-linear-gradient(128deg, rgb(255 77 61 / 12%) 0 2px, transparent 2px 32px);
    --theme-hero-glow: linear-gradient(116deg, transparent 0%, rgb(255 77 61 / 17%) 46%, transparent 80%);
}

.theme-lucia {
    --theme-background: #0d1019;
    --theme-background-soft: #161a27;
    --theme-surface: #1b2130;
    --theme-surface-raised: #242b3c;
    --theme-surface-border: #424b60;
    --theme-accent: #f5d88b;
    --theme-accent-strong: #ffffff;
    --theme-header-bg: rgb(13 16 25 / 94%);
    --theme-header-border: rgb(245 216 139 / 64%);
    --theme-page-gradient: linear-gradient(180deg, rgb(13 16 25 / 98%), rgb(22 26 39 / 100%) 42%, rgb(5 8 13 / 100%));
    --theme-page-texture: repeating-radial-gradient(circle at 0 0, rgb(245 216 139 / 16%) 0 1px, transparent 1px 42px), repeating-linear-gradient(90deg, rgb(255 255 255 / 4%) 0 1px, transparent 1px 36px);
    --theme-page-effect: linear-gradient(116deg, transparent 0%, rgb(245 216 139 / 13%) 48%, transparent 78%), linear-gradient(250deg, transparent 6%, rgb(255 255 255 / 8%) 55%, transparent 84%);
    --theme-page-effect-opacity: 0.48;
    --theme-hero-overlay:
        linear-gradient(90deg, rgb(13 16 25 / 96%) 0%, rgb(13 16 25 / 76%) 38%, rgb(13 16 25 / 20%) 74%, rgb(13 16 25 / 82%) 100%),
        linear-gradient(0deg, rgb(13 16 25 / 96%) 0%, rgb(13 16 25 / 30%) 54%, rgb(13 16 25 / 12%) 100%);
    --theme-hero-pattern: repeating-radial-gradient(circle at 0 0, rgb(245 216 139 / 18%) 0 1px, transparent 1px 34px), repeating-linear-gradient(90deg, rgb(255 255 255 / 8%) 0 1px, transparent 1px 30px);
    --theme-hero-glow: linear-gradient(118deg, transparent 0%, rgb(245 216 139 / 18%) 48%, transparent 80%);
}

.theme-new-year {
    --theme-background: #0f0f13;
    --theme-background-soft: #1a1a20;
    --theme-surface: #202027;
    --theme-surface-raised: #2a2a33;
    --theme-surface-border: #4a4658;
    --theme-accent: #e8c766;
    --theme-accent-strong: #8fd8ff;
    --theme-header-bg: rgb(15 15 19 / 95%);
    --theme-header-border: rgb(232 199 102 / 66%);
    --theme-page-gradient: linear-gradient(180deg, rgb(15 15 19 / 98%), rgb(28 28 36 / 100%) 40%, rgb(5 8 13 / 100%));
    --theme-page-texture: repeating-radial-gradient(circle at 0 0, rgb(232 199 102 / 18%) 0 1px, transparent 1px 30px), repeating-linear-gradient(118deg, rgb(143 216 255 / 5%) 0 1px, transparent 1px 36px);
    --theme-page-effect: linear-gradient(118deg, transparent 0%, rgb(232 199 102 / 14%) 48%, transparent 78%), linear-gradient(250deg, transparent 8%, rgb(143 216 255 / 12%) 55%, transparent 84%);
    --theme-page-effect-opacity: 0.54;
    --theme-hero-overlay:
        linear-gradient(90deg, rgb(15 15 19 / 96%) 0%, rgb(15 15 19 / 76%) 38%, rgb(15 15 19 / 20%) 74%, rgb(15 15 19 / 82%) 100%),
        linear-gradient(0deg, rgb(15 15 19 / 96%) 0%, rgb(15 15 19 / 30%) 54%, rgb(15 15 19 / 12%) 100%);
    --theme-hero-pattern: repeating-radial-gradient(circle at 0 0, rgb(232 199 102 / 22%) 0 1px, transparent 1px 26px), repeating-linear-gradient(118deg, rgb(143 216 255 / 8%) 0 1px, transparent 1px 30px);
    --theme-hero-glow: linear-gradient(116deg, transparent 0%, rgb(232 199 102 / 18%) 46%, transparent 80%);
}

* {
    box-sizing: border-box;
}

html {
    background: var(--color-bg);
}

body {
    position: relative;
    isolation: isolate;
    margin: 0;
    min-height: 100vh;
    background: var(--theme-page-texture), var(--theme-page-gradient), var(--color-bg);
    color: var(--color-text);
    font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    line-height: 1.5;
}

body::before {
    position: fixed;
    inset: 0;
    z-index: 0;
    content: "";
    pointer-events: none;
    background: var(--theme-page-image);
    background-position: center top;
    background-repeat: no-repeat;
    background-size: cover;
    filter: saturate(0.72) brightness(0.86) contrast(1);
    opacity: var(--theme-page-image-opacity);
}

body::after {
    position: fixed;
    inset: 0;
    z-index: 0;
    content: "";
    pointer-events: none;
    background: var(--theme-page-effect);
    opacity: var(--theme-page-effect-opacity);
}

.site-header,
main,
.site-footer {
    position: relative;
    z-index: 1;
}

a {
    color: inherit;
    text-decoration: none;
}

button,
input {
    font: inherit;
}

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

.wysiwyg-shell {
    display: grid;
    gap: 0;
    overflow: visible;
    border: 1px solid var(--color-surface-border);
    border-radius: 8px;
    background: var(--color-bg);
}

.wysiwyg-shell.is-dragging-image {
    border-color: rgb(245 184 0 / 72%);
    box-shadow: 0 0 0 3px rgb(245 184 0 / 18%), 0 18px 50px rgb(0 0 0 / 32%);
}

.wysiwyg-toolbar {
    position: sticky;
    top: 0;
    z-index: 12;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    padding: 8px;
    border-bottom: 1px solid var(--color-surface-border);
    border-radius: 8px 8px 0 0;
    background: rgb(17 24 32 / 96%);
    box-shadow: 0 12px 28px rgb(0 0 0 / 24%);
    backdrop-filter: blur(12px);
}

.wysiwyg-toolbar__button {
    min-width: 34px;
    min-height: 34px;
    border: 1px solid rgb(255 255 255 / 13%);
    border-radius: 6px;
    background: rgb(255 255 255 / 4%);
    color: var(--color-text);
    cursor: pointer;
    font-size: 0.78rem;
    font-weight: 850;
    line-height: 1;
    padding: 8px 10px;
}

.wysiwyg-toolbar__button:hover,
.wysiwyg-toolbar__button:focus-visible,
.wysiwyg-toolbar__button.is-active {
    border-color: rgb(245 184 0 / 58%);
    background: rgb(245 184 0 / 16%);
    color: var(--color-accent-strong);
}

.wysiwyg-editor {
    position: relative;
    min-height: 340px;
    padding: 18px;
}

.wysiwyg-shell.is-dragging-image .wysiwyg-editor::after {
    position: absolute;
    inset: 12px;
    display: grid;
    place-items: center;
    border: 1px dashed rgb(245 184 0 / 72%);
    border-radius: 8px;
    background: rgb(5 8 13 / 78%);
    color: var(--color-accent-strong);
    content: "Släpp bilden här";
    font-weight: 850;
    pointer-events: none;
}

.wysiwyg-upload-status {
    padding: 8px 12px;
    border-top: 1px solid var(--color-surface-border);
    background: rgb(245 184 0 / 11%);
    color: var(--color-accent-strong);
    font-size: 0.84rem;
    font-weight: 750;
}

.wysiwyg-upload-status.is-error {
    background: rgb(239 68 68 / 12%);
    color: #fecaca;
}

.wysiwyg-media-library {
    position: fixed;
    z-index: 80;
    inset: 0;
    display: grid;
    place-items: center;
    padding: 24px;
    background: rgb(0 0 0 / 68%);
}

.wysiwyg-media-library[hidden] {
    display: none;
}

.wysiwyg-media-library__panel {
    width: min(980px, 100%);
    max-height: min(760px, calc(100vh - 48px));
    display: grid;
    grid-template-rows: auto auto auto 1fr;
    gap: 12px;
    overflow: hidden;
    border: 1px solid var(--color-surface-border);
    border-radius: 8px;
    background: var(--color-bg-soft);
    box-shadow: 0 24px 80px rgb(0 0 0 / 48%);
    padding: 16px;
}

.wysiwyg-media-library__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.wysiwyg-media-library__header h2 {
    margin: 0;
    color: var(--color-text);
    font-size: 1rem;
}

.wysiwyg-media-library__close {
    border: 1px solid rgb(255 255 255 / 14%);
    border-radius: 6px;
    background: rgb(255 255 255 / 6%);
    color: var(--color-text);
    cursor: pointer;
    font-weight: 800;
    padding: 8px 10px;
}

.wysiwyg-media-library__search {
    width: 100%;
    border: 1px solid var(--color-surface-border);
    border-radius: 6px;
    background: var(--color-bg);
    color: var(--color-text);
    padding: 10px 12px;
}

.wysiwyg-media-library__status {
    min-height: 1.2em;
    color: var(--color-muted);
    font-size: 0.86rem;
}

.wysiwyg-media-library__grid {
    min-height: 180px;
    overflow: auto;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    gap: 10px;
    padding-right: 4px;
}

.wysiwyg-media-library__item {
    display: grid;
    grid-template-rows: 96px auto auto;
    gap: 8px;
    min-width: 0;
    border: 1px solid rgb(255 255 255 / 12%);
    border-radius: 8px;
    background: rgb(255 255 255 / 4%);
    color: var(--color-text);
    cursor: pointer;
    padding: 8px;
    text-align: left;
}

.wysiwyg-media-library__item:hover,
.wysiwyg-media-library__item:focus-visible {
    border-color: rgb(245 184 0 / 58%);
    background: rgb(245 184 0 / 12%);
    outline: none;
}

.wysiwyg-media-library__item img {
    width: 100%;
    height: 96px;
    object-fit: cover;
    border-radius: 6px;
    background: var(--color-bg);
}

.wysiwyg-media-library__meta {
    overflow: hidden;
    color: var(--color-text);
    font-size: 0.82rem;
    font-weight: 750;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.wysiwyg-media-library__badge {
    width: fit-content;
    border-radius: 999px;
    background: rgb(255 255 255 / 8%);
    color: var(--color-muted);
    font-size: 0.72rem;
    font-weight: 800;
    padding: 4px 7px;
}

.wysiwyg-editor__content {
    min-height: 300px;
    outline: none;
}

.wysiwyg-editor__content > *:first-child {
    margin-top: 0;
}

.wysiwyg-editor__content > *:last-child {
    margin-bottom: 0;
}

.wysiwyg-editor__content a {
    color: var(--color-accent-strong);
    text-decoration: underline;
    text-underline-offset: 3px;
}

.wysiwyg-editor__content img,
.article-body img,
.content-prose img {
    width: 100%;
    height: auto;
    margin-block: 18px;
    border: 1px solid var(--color-surface-border);
    border-radius: 8px;
    background: var(--color-bg);
}

.wysiwyg-editor__content div[data-youtube-video],
.article-body div[data-youtube-video],
.content-prose div[data-youtube-video] {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 9;
    margin-block: 22px;
    overflow: hidden;
    border: 1px solid var(--color-surface-border);
    border-radius: 8px;
    background: var(--color-bg);
}

.article-body > iframe,
.content-prose > iframe {
    width: 100%;
    aspect-ratio: 16 / 9;
    margin-block: 22px;
    border: 1px solid var(--color-surface-border);
    border-radius: 8px;
    background: var(--color-bg);
}

.wysiwyg-editor__content div[data-youtube-video] iframe,
.article-body div[data-youtube-video] iframe,
.article-body > iframe,
.content-prose div[data-youtube-video] iframe,
.content-prose > iframe {
    display: block;
    width: 100%;
    height: 100%;
    border: 0;
}

.preview-banner {
    display: flex;
    flex-wrap: wrap;
    gap: 10px 14px;
    align-items: center;
    justify-content: space-between;
    margin-top: 24px;
    padding: 12px 16px;
    border: 1px solid rgb(245 184 0 / 48%);
    border-radius: 8px;
    background: rgb(245 184 0 / 12%);
    color: var(--color-text);
}

.preview-banner strong {
    color: var(--color-accent-strong);
}

.preview-banner span {
    color: var(--color-muted);
}

.preview-banner a {
    color: var(--color-accent-strong);
    font-weight: 700;
    text-decoration: none;
}

.editor-action-bar {
    display: flex;
    justify-content: flex-end;
    margin-top: 18px;
}

.editor-action-bar__button {
    width: auto;
    min-height: 38px;
    padding: 10px 16px;
}

.site-container {
    width: min(var(--site-width), calc(100% - 48px));
    margin-inline: auto;
}

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.site-header {
    position: relative;
    z-index: 10;
    background: var(--theme-header-bg);
    border-bottom: 1px solid var(--theme-header-border);
    box-shadow: 0 1px 0 rgb(255 255 255 / 4%) inset;
}

.site-header__top,
.site-header__main {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 28px;
}

.site-header__top {
    min-height: 42px;
    color: var(--color-muted);
    font-size: 0.82rem;
    border-bottom: 1px solid rgb(255 255 255 / 7%);
}

.site-tagline {
    margin: 0;
    text-transform: uppercase;
}

.site-actions,
.main-nav {
    display: flex;
    align-items: center;
    gap: clamp(10px, 1.25vw, 20px);
}

.site-actions__language,
.site-actions__public,
.site-actions__system {
    display: flex;
    align-items: center;
    gap: clamp(10px, 1.4vw, 18px);
}

.site-actions a,
.site-actions span,
.main-nav a,
.main-nav__trigger {
    font-size: 0.86rem;
    font-weight: 800;
    text-transform: uppercase;
}

.site-actions a,
.site-actions span {
    color: var(--color-text);
}

.site-actions__admin {
    color: var(--color-accent-strong) !important;
}

.language-pill {
    color: var(--color-accent);
}

.site-header__main {
    min-height: 72px;
}

.site-logo {
    position: relative;
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
}

.site-logo picture,
.site-footer picture {
    display: inline-flex;
    align-items: center;
}

.site-logo img {
    display: block;
    width: auto;
    max-width: 228px;
    max-height: 58px;
    height: auto;
    object-fit: contain;
}

.site-logo--variant::after {
    position: absolute;
    right: 0;
    bottom: -6px;
    left: 0;
    height: 2px;
    content: "";
    background: linear-gradient(90deg, transparent, var(--color-accent), transparent);
}

.main-nav {
    color: var(--color-text);
    margin-left: auto;
}

.main-nav a,
.main-nav__trigger {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding-block: 26px;
}

.main-nav__group {
    position: relative;
    display: inline-flex;
    align-items: center;
}

.main-nav__trigger {
    color: inherit;
    cursor: pointer;
    background: transparent;
    border: 0;
    border-radius: 6px;
    font-family: inherit;
    transition: background-color 160ms ease, color 160ms ease;
}

.main-nav__caret {
    width: 0;
    height: 0;
    border-top: 4px solid currentColor;
    border-right: 4px solid transparent;
    border-left: 4px solid transparent;
    opacity: 0.76;
    transform: translateY(1px);
    transition: color 160ms ease, opacity 160ms ease, transform 160ms ease;
}

.main-nav a::after,
.main-nav__trigger::after {
    position: absolute;
    right: 0;
    bottom: 18px;
    left: 0;
    height: 2px;
    content: "";
    background: var(--color-accent);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 160ms ease;
}

.main-nav a:hover::after,
.main-nav a:focus-visible::after,
.main-nav a[aria-current="page"]::after,
.main-nav__trigger[aria-current="page"]::after,
.main-nav__group:hover .main-nav__trigger::after,
.main-nav__group:focus-within .main-nav__trigger::after {
    transform: scaleX(1);
}

.main-nav__trigger[aria-current="page"],
.main-nav__group:hover .main-nav__trigger,
.main-nav__group:focus-within .main-nav__trigger {
    color: var(--color-text);
    background: rgb(245 184 0 / 8%);
}

.main-nav__trigger[aria-current="page"] .main-nav__caret,
.main-nav__group:hover .main-nav__caret,
.main-nav__group:focus-within .main-nav__caret {
    color: var(--color-accent-strong);
    opacity: 1;
    transform: translateY(1px) rotate(180deg);
}

.main-nav__submenu {
    position: absolute;
    top: calc(100% - 8px);
    left: 50%;
    z-index: 20;
    display: grid;
    gap: 3px;
    min-width: 246px;
    padding: 12px;
    visibility: hidden;
    background: rgb(11 17 24 / 98%);
    border: 1px solid var(--color-surface-border);
    border-radius: 8px;
    box-shadow: 0 18px 44px rgb(0 0 0 / 36%);
    opacity: 0;
    transform: translate(-50%, 8px);
    transition: opacity 160ms ease, transform 160ms ease, visibility 160ms ease;
}

.main-nav__submenu::before {
    position: absolute;
    top: 0;
    right: 12px;
    left: 12px;
    height: 2px;
    content: "";
    background: linear-gradient(90deg, transparent, var(--color-accent), transparent);
}

.main-nav__group:hover .main-nav__submenu,
.main-nav__group:focus-within .main-nav__submenu {
    visibility: visible;
    opacity: 1;
    transform: translate(-50%, 0);
}

.main-nav__submenu .main-nav__submenu-link {
    display: flex;
    align-items: center;
    min-height: 40px;
    padding: 11px 12px;
    border-radius: 6px;
    color: rgb(245 247 250 / 88%);
    transition: background-color 150ms ease, color 150ms ease, box-shadow 150ms ease, transform 150ms ease;
}

.main-nav__submenu .main-nav__submenu-link::after {
    display: none;
}

.main-nav__submenu .main-nav__submenu-link:hover,
.main-nav__submenu .main-nav__submenu-link:focus-visible,
.main-nav__submenu .main-nav__submenu-link[aria-current="page"] {
    background: linear-gradient(90deg, rgb(245 184 0 / 12%), rgb(255 255 255 / 6%));
    box-shadow: inset 3px 0 0 var(--color-accent);
    color: var(--color-text);
    transform: translateX(2px);
}

.site-mobile-toggle,
.site-mobile-menu {
    display: none;
}

.site-mobile-toggle {
    align-items: center;
    gap: 10px;
    min-height: 42px;
    padding: 0 12px;
    color: var(--color-text);
    font: inherit;
    font-size: 0.86rem;
    font-weight: 900;
    text-transform: uppercase;
    cursor: pointer;
    background: rgb(255 255 255 / 5%);
    border: 1px solid var(--color-surface-border);
    border-radius: 8px;
}

.site-mobile-toggle__icon,
.site-mobile-toggle__icon::before,
.site-mobile-toggle__icon::after {
    display: block;
    width: 18px;
    height: 2px;
    content: "";
    background: currentColor;
    border-radius: 999px;
}

.site-mobile-toggle__icon {
    position: relative;
}

.site-mobile-toggle__icon::before,
.site-mobile-toggle__icon::after {
    position: absolute;
    left: 0;
}

.site-mobile-toggle__icon::before {
    top: -6px;
}

.site-mobile-toggle__icon::after {
    top: 6px;
}

.site-mobile-menu[hidden],
.site-mobile-menu__children[hidden] {
    display: none !important;
}

.site-mobile-menu-open {
    overflow: hidden;
}

.site-mobile-menu__backdrop {
    position: fixed;
    inset: 0;
    z-index: 80;
    cursor: pointer;
    background: rgb(0 0 0 / 62%);
    border: 0;
}

.site-mobile-menu__panel {
    position: fixed;
    inset: 0 0 0 auto;
    z-index: 90;
    display: flex;
    flex-direction: column;
    width: min(420px, 92vw);
    max-height: 100vh;
    padding: 18px;
    overflow-y: auto;
    color: var(--color-text);
    background: var(--color-bg-soft);
    border-left: 1px solid var(--color-surface-border);
    box-shadow: -22px 0 52px rgb(0 0 0 / 42%);
}

.site-mobile-menu__header,
.site-mobile-menu__system {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.site-mobile-menu__header {
    padding-bottom: 14px;
    border-bottom: 1px solid rgb(255 255 255 / 10%);
}

.site-mobile-menu__title {
    font-size: 0.95rem;
    font-weight: 900;
    text-transform: uppercase;
}

.site-mobile-menu__close {
    min-height: 36px;
    padding: 0 12px;
    color: var(--color-text);
    font: inherit;
    font-size: 0.78rem;
    font-weight: 900;
    text-transform: uppercase;
    cursor: pointer;
    background: rgb(255 255 255 / 6%);
    border: 1px solid var(--color-surface-border);
    border-radius: 8px;
}

.site-mobile-menu__nav {
    display: grid;
    gap: 8px;
    padding-block: 16px;
    border-bottom: 1px solid rgb(255 255 255 / 10%);
}

.site-mobile-menu__nav--secondary {
    padding-top: 4px;
}

.site-mobile-menu__link,
.site-mobile-menu__summary,
.site-mobile-menu__system a,
.site-mobile-menu__system span {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 42px;
    padding: 0 12px;
    color: var(--color-text);
    font-size: 0.9rem;
    font-weight: 900;
    text-transform: uppercase;
    background: rgb(255 255 255 / 4%);
    border: 1px solid rgb(255 255 255 / 8%);
    border-radius: 8px;
}

.site-mobile-menu__summary {
    width: 100%;
    font-family: inherit;
    cursor: pointer;
}

.site-mobile-menu__summary-indicator {
    position: relative;
    flex: 0 0 auto;
    width: 22px;
    height: 22px;
    border: 1px solid rgb(255 255 255 / 13%);
    border-radius: 999px;
    background: rgb(255 255 255 / 5%);
}

.site-mobile-menu__summary-indicator::before,
.site-mobile-menu__summary-indicator::after {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 10px;
    height: 2px;
    content: "";
    background: currentColor;
    border-radius: 999px;
    transform: translate(-50%, -50%);
    transition: opacity 150ms ease, transform 150ms ease;
}

.site-mobile-menu__summary-indicator::after {
    transform: translate(-50%, -50%) rotate(90deg);
}

.site-mobile-menu__summary[aria-current="page"],
.site-mobile-menu__summary[aria-expanded="true"] {
    border-color: rgb(245 184 0 / 34%);
    background: rgb(245 184 0 / 10%);
}

.site-mobile-menu__summary[aria-expanded="true"] .site-mobile-menu__summary-indicator {
    border-color: rgb(245 184 0 / 32%);
    color: var(--color-accent-strong);
    background: rgb(245 184 0 / 11%);
}

.site-mobile-menu__summary[aria-expanded="true"] .site-mobile-menu__summary-indicator::after {
    opacity: 0;
    transform: translate(-50%, -50%) rotate(0deg);
}

.site-mobile-menu__children {
    display: grid;
    gap: 7px;
    margin-left: 10px;
    padding: 8px 0 0 13px;
    border-left: 1px solid rgb(245 184 0 / 18%);
}

.site-mobile-menu__children .site-mobile-menu__link {
    min-height: 38px;
    font-size: 0.82rem;
    color: var(--color-muted);
}

.site-mobile-menu__link[aria-current="page"],
.site-mobile-menu__children .site-mobile-menu__link:hover,
.site-mobile-menu__children .site-mobile-menu__link:focus-visible {
    border-color: rgb(245 184 0 / 30%);
    background: rgb(245 184 0 / 9%);
    color: var(--color-text);
}

.site-mobile-menu__system {
    flex-wrap: wrap;
    justify-content: flex-start;
    padding-top: 16px;
}

.front-page {
    overflow: hidden;
}

.portal-hero {
    --portal-hero-height: clamp(640px, 66vh, 740px);
    --portal-hero-media-width: clamp(320px, 34vw, 460px);
    --portal-hero-content-width: min(640px, calc(100% - var(--portal-hero-media-width) - clamp(88px, 9vw, 136px)));

    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(300px, 360px);
    width: min(var(--site-width), calc(100% - 48px));
    min-height: var(--portal-hero-height);
    margin: 18px auto 0;
    overflow: hidden;
    border: 1px solid rgb(255 255 255 / 10%);
    border-radius: 8px;
    background: var(--color-bg);
}

.portal-hero__feature {
    position: relative;
    isolation: isolate;
    display: block;
    height: var(--portal-hero-height);
    min-height: var(--portal-hero-height);
    overflow: hidden;
}

.portal-hero__slide {
    position: absolute;
    inset: 0;
    display: block;
    min-height: var(--portal-hero-height);
    opacity: 0;
    pointer-events: none;
    visibility: hidden;
    transition:
        opacity 220ms ease,
        visibility 220ms ease;
}

.portal-hero__slide.is-active {
    opacity: 1;
    pointer-events: auto;
    visibility: visible;
}

.portal-hero__media-wrap {
    position: absolute;
    inset: 0;
    overflow: hidden;
    pointer-events: none;
}

.portal-hero__media-wrap::before {
    position: absolute;
    inset: 0;
    content: "";
    background:
        radial-gradient(circle at 84% 32%, rgb(245 184 0 / 16%), transparent 30%),
        linear-gradient(90deg, rgb(5 8 13 / 8%), rgb(5 8 13 / 34%) 62%, rgb(5 8 13 / 18%));
}

.portal-hero__media {
    position: absolute;
    top: 50%;
    right: clamp(26px, 3.4vw, 52px);
    width: var(--portal-hero-media-width);
    min-width: 280px;
    aspect-ratio: 16 / 10;
    overflow: hidden;
    border: 1px solid rgb(255 255 255 / 14%);
    border-radius: 8px;
    background:
        linear-gradient(145deg, rgb(255 255 255 / 6%), rgb(255 255 255 / 0)),
        rgb(8 13 19 / 64%);
    box-shadow:
        0 26px 70px rgb(0 0 0 / 32%),
        0 0 0 1px rgb(245 184 0 / 8%) inset;
    transform: translateY(-50%);
}

.portal-hero__media-wrap--season .portal-hero__media {
    border-color: rgb(255 255 255 / 20%);
    box-shadow:
        0 26px 70px rgb(0 0 0 / 34%),
        0 0 0 1px rgb(245 184 0 / 22%) inset,
        0 0 32px rgb(245 184 0 / 12%);
}

.portal-hero__media--theme img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    background: radial-gradient(circle at center, rgb(255 255 255 / 6%), rgb(5 8 13 / 28%) 72%);
}

.portal-hero__season {
    position: absolute;
    z-index: 3;
    top: clamp(34px, 4vw, 58px);
    right: clamp(34px, 4.2vw, 62px);
    display: grid;
    max-width: min(210px, 34%);
    gap: 3px;
    padding: 10px 12px;
    border: 1px solid rgb(255 255 255 / 20%);
    border-radius: 6px;
    background: linear-gradient(135deg, rgb(5 8 13 / 72%), rgb(17 24 32 / 54%));
    box-shadow: 0 12px 28px rgb(0 0 0 / 24%);
    opacity: 0.9;
}

.portal-hero__season span,
.portal-hero__season strong {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.portal-hero__season span {
    color: var(--color-accent-strong);
    font-size: 0.68rem;
    font-weight: 900;
    line-height: 1;
    text-transform: uppercase;
}

.portal-hero__season strong {
    color: var(--color-text);
    font-size: 0.9rem;
    line-height: 1.12;
}

.portal-hero__feature::before {
    position: absolute;
    inset: 0;
    z-index: 1;
    content: "";
    pointer-events: none;
    background: var(--theme-hero-pattern), var(--theme-hero-glow);
    opacity: 0.8;
}

.portal-hero__feature::after {
    position: absolute;
    inset: 0;
    z-index: 2;
    content: "";
    background: var(--theme-hero-overlay);
}

.portal-hero__content {
    position: relative;
    z-index: 4;
    display: flex;
    width: var(--portal-hero-content-width);
    min-height: var(--portal-hero-height);
    flex-direction: column;
    justify-content: flex-start;
    margin-inline: clamp(24px, 4vw, 54px) auto;
    padding-block: clamp(46px, 6vw, 70px) clamp(40px, 5vw, 58px);
}

.section-kicker,
.panel-title,
.section-heading h2 {
    color: var(--color-text);
    font-size: 0.98rem;
    font-weight: 900;
    line-height: 1.1;
    margin: 0;
    text-transform: uppercase;
}

.section-kicker {
    color: var(--color-accent-strong);
    margin-bottom: 12px;
}

.section-heading {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 18px;
}

.section-heading::before,
.panel-title::before {
    display: inline-block;
    width: 4px;
    height: 20px;
    margin-right: 8px;
    content: "";
    vertical-align: -4px;
    background: var(--color-accent);
}

.portal-hero__title {
    max-width: 600px;
    min-height: 3.35em;
    margin: 0;
    color: #fff;
    display: flex;
    align-items: end;
    font-size: clamp(2.45rem, 3.7rem, 4.1rem);
    font-weight: 950;
    letter-spacing: 0;
    line-height: 0.98;
    text-wrap: balance;
}

.portal-hero__lead {
    max-width: 640px;
    min-height: 3.2em;
    margin: 24px 0 0;
    color: #eef2f6;
    font-size: clamp(1.05rem, 1.5vw, 1.28rem);
}

.platform-list {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 22px;
}

.platform-list span,
.meta-row span {
    min-height: 28px;
    border: 1px solid rgb(255 255 255 / 52%);
    border-radius: 4px;
    color: var(--color-text);
    font-size: 0.76rem;
    font-weight: 800;
    line-height: 1;
    padding: 7px 10px;
    text-transform: uppercase;
}

.review-summary {
    display: grid;
    grid-template-columns: 124px minmax(140px, 1fr) minmax(140px, 1fr) auto;
    align-items: center;
    gap: 18px;
    width: min(760px, 100%);
    min-height: 128px;
    margin-top: auto;
    padding-top: 24px;
    border-top: 1px solid rgb(255 255 255 / 16%);
}

.score-badge-wrap {
    display: grid;
    width: min(100%, 124px);
    justify-items: center;
    gap: 8px;
}

.score-badge-wrap--large {
    width: min(100%, 132px);
}

.preview-summary {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 18px;
    width: min(520px, 100%);
    min-height: 106px;
    margin-top: auto;
    padding-top: 26px;
    border-top: 1px solid rgb(255 255 255 / 16%);
}

.score-badge {
    --score-progress: 0%;

    position: relative;
    display: grid;
    width: 124px;
    aspect-ratio: 1;
    min-height: 124px;
    place-items: center;
    align-content: center;
    gap: 8px;
    overflow: hidden;
    color: var(--color-text);
    background:
        conic-gradient(var(--color-accent-strong) 0 var(--score-progress), rgb(255 255 255 / 16%) var(--score-progress) 100%),
        linear-gradient(180deg, rgb(9 18 27 / 98%), rgb(2 6 12 / 98%));
    border: 0;
    border-radius: 8px;
    box-shadow:
        0 20px 38px rgb(0 0 0 / 38%),
        0 0 0 1px rgb(255 255 255 / 11%) inset;
    text-align: center;
}

.score-badge::before {
    position: absolute;
    inset: 6px;
    content: "";
    border-radius: 5px;
    background:
        radial-gradient(circle at 50% 10%, rgb(255 255 255 / 12%), transparent 35%),
        linear-gradient(180deg, rgb(9 18 27 / 98%), rgb(2 6 12 / 98%));
    box-shadow: 0 0 0 1px rgb(255 255 255 / 8%) inset;
}

.score-badge strong {
    position: relative;
    z-index: 1;
    display: block;
    color: #fff;
    font-size: 2.7rem;
    font-variant-numeric: tabular-nums;
    font-weight: 950;
    line-height: 1;
}

.score-badge span {
    position: relative;
    z-index: 1;
    display: block;
    color: rgb(238 242 246 / 78%);
    font-size: 0.68rem;
    font-weight: 900;
    line-height: 1;
    text-transform: uppercase;
}

.score-badge span:last-child {
    color: var(--color-accent-strong);
}

.content-label-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    min-width: 0;
}

.score-level-chip {
    --score-step-accent: var(--color-accent);

    display: inline-flex;
    max-width: 100%;
    min-height: 24px;
    align-items: center;
    justify-content: center;
    border: 1px solid color-mix(in srgb, var(--score-step-accent) 56%, white 12%);
    border-radius: 999px;
    background: color-mix(in srgb, var(--score-step-accent) 16%, rgb(5 8 13 / 92%));
    color: color-mix(in srgb, var(--score-step-accent) 64%, white 32%);
    font-size: 0.68rem;
    font-weight: 950;
    line-height: 1.1;
    overflow-wrap: anywhere;
    padding: 5px 8px;
    text-align: center;
    text-transform: uppercase;
    white-space: normal;
}

.review-card__body > .score-level-chip {
    justify-self: start;
}

.score-level-chip--rating-step-1,
.score-corner--rating-step-1 {
    --score-step-accent: #ef4444;
}

.score-level-chip--rating-step-2,
.score-corner--rating-step-2 {
    --score-step-accent: #f97316;
}

.score-level-chip--rating-step-3,
.score-corner--rating-step-3 {
    --score-step-accent: #f59e0b;
}

.score-level-chip--rating-step-4,
.score-corner--rating-step-4 {
    --score-step-accent: #facc15;
}

.score-level-chip--rating-step-5,
.score-corner--rating-step-5 {
    --score-step-accent: #84cc16;
}

.score-level-chip--rating-step-6,
.score-corner--rating-step-6 {
    --score-step-accent: #38bdf8;
}

.score-level-chip--rating-step-7,
.score-corner--rating-step-7 {
    --score-step-accent: #a78bfa;
}

.score-level-chip--rating-step-8,
.score-corner--rating-step-8 {
    --score-step-accent: #f472b6;
}

.score-level-chip--rating-step-9,
.score-corner--rating-step-9 {
    --score-step-accent: #c084fc;
}

.score-level-chip--rating-step-10,
.score-corner--rating-step-10 {
    --score-step-accent: #fbbf24;
}

.score-badge--pending {
    background:
        linear-gradient(135deg, rgb(255 255 255 / 7%), rgb(255 255 255 / 2%)) padding-box,
        linear-gradient(155deg, rgb(255 255 255 / 22%), rgb(245 184 0 / 28)) border-box;
    box-shadow:
        0 14px 26px rgb(0 0 0 / 24%),
        0 0 0 1px rgb(255 255 255 / 7%) inset;
}

.score-badge--pending strong {
    color: var(--color-accent-strong);
    font-size: 1.02rem;
    text-transform: uppercase;
}

.score-badge--pending span,
.score-badge--pending span:last-child {
    color: var(--color-muted);
}

.summary-list {
    display: grid;
    gap: 5px;
    margin: 0;
    padding: 0;
    color: #d8dde3;
    font-size: 0.87rem;
    list-style: none;
}

.summary-list li::before {
    display: inline-block;
    width: 16px;
    color: var(--color-muted);
    font-weight: 900;
}

.summary-list--positive li::before {
    color: var(--color-success);
    content: "+";
}

.summary-list--negative li::before {
    color: var(--color-muted);
    content: "–";
}

.button {
    display: inline-flex;
    min-height: 42px;
    align-items: center;
    justify-content: center;
    border: 1px solid rgb(255 255 255 / 22%);
    border-radius: 4px;
    color: var(--color-text);
    font-size: 0.84rem;
    font-weight: 900;
    line-height: 1;
    padding: 12px 22px;
    text-transform: uppercase;
    transition:
        background-color 160ms ease,
        border-color 160ms ease,
        color 160ms ease,
        transform 160ms ease;
}

.button:hover,
.button:focus-visible {
    transform: translateY(-1px);
}

.button--primary {
    border-color: var(--color-accent);
    background: linear-gradient(180deg, var(--color-accent-strong), var(--color-accent));
    color: #221700;
}

.button--ghost {
    width: 100%;
    background: rgb(255 255 255 / 2%);
}

.button--center {
    display: flex;
    width: min(280px, 100%);
    margin: 22px auto 0;
}

.portal-hero__side {
    display: flex;
    flex-direction: column;
    gap: 18px;
    padding: 30px 28px;
    background: linear-gradient(180deg, #080d13, #05080d);
    border-left: 1px solid rgb(255 255 255 / 10%);
}

.portal-hero__controls {
    position: absolute;
    z-index: 4;
    right: 24px;
    bottom: 22px;
    display: flex;
    align-items: center;
    gap: 10px;
}

.portal-hero__controls button {
    display: grid;
    min-width: 36px;
    min-height: 36px;
    place-items: center;
    border: 1px solid rgb(255 255 255 / 28%);
    border-radius: 4px;
    background: rgb(5 8 13 / 78%);
    color: var(--color-text);
    cursor: pointer;
    font-size: 1rem;
    font-weight: 900;
}

.portal-hero__dots {
    display: flex;
    gap: 7px;
}

.portal-hero__dots button {
    min-width: 10px;
    min-height: 10px;
    border-radius: 999px;
    padding: 0;
    background: rgb(255 255 255 / 30%);
}

.portal-hero__controls button:hover,
.portal-hero__controls button:focus-visible,
.portal-hero__dots button.is-active {
    border-color: var(--color-accent);
    background: var(--color-accent);
    color: #1f1600;
}

.discovery-nav {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 14px;
    padding-block: 18px 6px;
}

.review-category-stats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 14px;
    padding-block: 10px 6px;
}

.review-category-stats a {
    display: grid;
    min-height: 84px;
    align-content: center;
    gap: 6px;
    border: 1px solid rgb(245 184 0 / 24%);
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgb(245 184 0 / 11%), rgb(255 255 255 / 0) 46%),
        linear-gradient(180deg, rgb(17 24 32 / 96%), rgb(8 13 19 / 96%));
    box-shadow: 0 1px 0 rgb(255 255 255 / 5%) inset;
    color: var(--color-text);
    padding: 16px;
    text-decoration: none;
}

.review-category-stats strong {
    color: var(--color-accent-strong);
    font-size: 1.55rem;
    line-height: 1;
}

.review-category-stats span {
    color: var(--color-muted);
    font-size: 0.94rem;
    line-height: 1.25;
}

.review-category-stats a:hover,
.review-category-stats a:focus-visible {
    border-color: rgb(245 184 0 / 62%);
}

.discovery-card {
    display: grid;
    min-height: 138px;
    align-content: end;
    gap: 8px;
    overflow: hidden;
    border: 1px solid rgb(255 255 255 / 11%);
    border-radius: 6px;
    background:
        linear-gradient(135deg, rgb(255 255 255 / 8%), rgb(255 255 255 / 0) 42%),
        linear-gradient(180deg, rgb(16 24 32 / 95%), rgb(8 13 19 / 96%));
    box-shadow: 0 1px 0 rgb(255 255 255 / 4%) inset;
    padding: 16px;
}

.discovery-card span,
.feature-heading a {
    color: var(--color-accent);
    font-size: 0.78rem;
    font-weight: 900;
    line-height: 1;
    text-transform: uppercase;
}

.discovery-card strong {
    color: var(--color-text);
    font-size: 1.12rem;
    line-height: 1.05;
}

.discovery-card small {
    color: var(--color-muted);
    font-size: 0.9rem;
    line-height: 1.35;
}

.discovery-card--blue {
    background:
        linear-gradient(135deg, rgb(34 211 238 / 16%), rgb(255 255 255 / 0) 42%),
        linear-gradient(180deg, rgb(16 24 32 / 95%), rgb(8 13 19 / 96%));
}

.discovery-card--kingdom {
    background:
        linear-gradient(135deg, rgb(245 184 0 / 16%), rgb(255 255 255 / 0) 42%),
        linear-gradient(180deg, rgb(16 24 32 / 95%), rgb(8 13 19 / 96%));
}

.discovery-card--preview {
    background:
        linear-gradient(135deg, rgb(96 165 250 / 15%), rgb(245 184 0 / 8%) 44%, rgb(255 255 255 / 0)),
        linear-gradient(180deg, rgb(16 24 32 / 95%), rgb(8 13 19 / 96%));
}

.discovery-card--indie {
    background:
        linear-gradient(135deg, rgb(34 197 94 / 18%), rgb(255 255 255 / 0) 42%),
        linear-gradient(180deg, rgb(16 24 32 / 95%), rgb(8 13 19 / 96%));
}

.discovery-card--hardware {
    background:
        linear-gradient(135deg, rgb(245 184 0 / 14%), rgb(239 68 68 / 10%) 42%, rgb(255 255 255 / 0)),
        linear-gradient(180deg, rgb(16 24 32 / 95%), rgb(8 13 19 / 96%));
}

.discovery-card--linux {
    background:
        linear-gradient(135deg, rgb(45 212 191 / 17%), rgb(34 211 238 / 8%) 44%, rgb(255 255 255 / 0)),
        linear-gradient(180deg, rgb(16 24 32 / 95%), rgb(8 13 19 / 96%));
}

.discovery-card--guide {
    background:
        linear-gradient(135deg, rgb(59 130 246 / 16%), rgb(34 197 94 / 10%) 44%, rgb(255 255 255 / 0)),
        linear-gradient(180deg, rgb(16 24 32 / 95%), rgb(8 13 19 / 96%));
}

.news-list {
    display: grid;
    gap: 16px;
}

.news-item,
.release-item,
.indie-item {
    display: grid;
    grid-template-columns: 92px minmax(0, 1fr);
    gap: 14px;
    align-items: center;
}

.news-item strong,
.release-item strong,
.indie-item strong {
    display: block;
    color: var(--color-text);
    font-size: 0.98rem;
    line-height: 1.25;
}

.news-item small,
.release-item time,
.indie-item small {
    display: block;
    margin-top: 6px;
    color: var(--color-muted);
    font-size: 0.78rem;
}

.thumb {
    display: block;
    aspect-ratio: 16 / 10;
    overflow: hidden;
    border: 1px solid rgb(255 255 255 / 10%);
    border-radius: 4px;
    background:
        linear-gradient(135deg, rgb(255 255 255 / 18%), rgb(255 255 255 / 0)),
        linear-gradient(135deg, #1e3a8a, #0f172a 60%, #111827);
}

.thumb img,
.review-card__media img,
.article-card__media img,
.indie-radar__lead .media-art img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.content-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(300px, 330px);
    gap: 24px;
    padding-block: 24px 0;
}

.content-main {
    display: grid;
    gap: 34px;
    min-width: 0;
}

.content-side {
    display: grid;
    align-content: start;
    gap: 18px;
}

.advertisement-slot {
    position: relative;
    display: grid;
    gap: 8px;
    min-width: 0;
    overflow: hidden;
    border: 1px solid rgb(245 184 0 / 28%);
    border-radius: 6px;
    background:
        linear-gradient(135deg, rgb(245 184 0 / 10%), rgb(15 185 177 / 5%)),
        linear-gradient(180deg, rgb(17 24 32 / 92%), rgb(8 13 19 / 92%));
    box-shadow: 0 1px 0 rgb(255 255 255 / 5%) inset;
    padding: 10px;
}

.advertisement-slot--top {
    margin-top: 18px;
}

.advertisement-slot--footer {
    margin-top: 32px;
}

.advertisement-slot__label {
    color: var(--color-muted);
    font-size: 0.68rem;
    font-weight: 900;
    line-height: 1;
    text-transform: uppercase;
}

.advertisement-slot__link,
.advertisement-slot__code {
    display: block;
    min-width: 0;
    overflow: hidden;
    border-radius: 4px;
}

.advertisement-slot__image {
    display: block;
    width: 100%;
    max-height: 180px;
    object-fit: cover;
}

.advertisement-slot--sidebar .advertisement-slot__image {
    aspect-ratio: 4 / 3;
    max-height: none;
}

.advertisement-slot--after-content .advertisement-slot__image,
.advertisement-slot--footer .advertisement-slot__image,
.advertisement-slot--top .advertisement-slot__image {
    aspect-ratio: 16 / 3;
}

.advertisement-slot__code iframe,
.advertisement-slot__code img {
    max-width: 100%;
}

.advertisement-slot__placeholder,
.embedded-media-placeholder {
    display: grid;
    gap: 8px;
    min-height: 132px;
    align-content: center;
    justify-items: start;
    padding: 18px;
    border: 1px solid rgb(154 164 175 / 22%);
    border-radius: 6px;
    background: rgb(5 8 13 / 54%);
    color: var(--color-muted);
}

.advertisement-slot__placeholder strong,
.embedded-media-placeholder strong {
    color: var(--color-text);
}

.advertisement-slot__placeholder button,
.embedded-media-placeholder button {
    border: 1px solid rgb(245 184 0 / 45%);
    border-radius: 4px;
    background: rgb(245 184 0 / 10%);
    color: var(--color-accent-strong);
    font: inherit;
    font-weight: 800;
    padding: 8px 11px;
    cursor: pointer;
}

.embedded-media-placeholder {
    margin-block: 18px;
}

.advertisement-slot__pixel {
    position: absolute;
    right: 0;
    bottom: 0;
    width: 1px;
    height: 1px;
    opacity: 0;
    pointer-events: none;
}

.cookie-consent__banner {
    position: fixed;
    right: 50%;
    bottom: 18px;
    z-index: 80;
    width: min(calc(100% - 36px), 980px);
    transform: translateX(50%);
}

.cookie-consent__banner[hidden],
.cookie-consent__modal[hidden],
.cookie-consent__settings[hidden] {
    display: none;
}

.cookie-consent__sheet {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 18px;
    align-items: center;
    padding: 16px;
    border: 1px solid rgb(245 184 0 / 34%);
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgb(245 184 0 / 9%), transparent 36%),
        rgb(11 17 24 / 96%);
    box-shadow: 0 18px 54px rgb(0 0 0 / 46%);
    backdrop-filter: blur(16px);
}

.cookie-consent__content {
    display: grid;
    gap: 5px;
}

.cookie-consent__content h2,
.cookie-consent__panel h2 {
    margin: 0;
    color: var(--color-text);
    font-size: 1rem;
    letter-spacing: 0;
}

.cookie-consent__content p,
.cookie-consent__panel p {
    margin: 0;
    color: var(--color-muted);
    line-height: 1.5;
}

.cookie-consent__eyebrow {
    color: var(--color-accent);
    font-size: 0.68rem;
    font-weight: 900;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.cookie-consent__actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
}

.cookie-consent__actions .button,
.cookie-consent__button {
    min-height: 40px;
    border-radius: 6px;
    white-space: nowrap;
}

.cookie-consent__settings {
    position: fixed;
    left: 14px;
    bottom: 14px;
    z-index: 70;
    border: 1px solid rgb(245 184 0 / 34%);
    border-radius: 999px;
    background: rgb(17 24 32 / 92%);
    color: var(--color-accent-strong);
    font: inherit;
    font-size: 0.78rem;
    font-weight: 900;
    padding: 9px 13px;
    cursor: pointer;
    box-shadow: 0 12px 30px rgb(0 0 0 / 28%);
    backdrop-filter: blur(10px);
}

.cookie-consent__modal {
    position: fixed;
    inset: 0;
    z-index: 90;
    display: grid;
    place-items: center;
    padding: 18px;
}

.cookie-consent__modal-backdrop {
    position: absolute;
    inset: 0;
    background: rgb(5 8 13 / 46%);
    backdrop-filter: blur(4px);
}

.cookie-consent__panel {
    position: relative;
    z-index: 1;
    display: grid;
    gap: 18px;
    width: min(100%, 620px);
    max-height: min(720px, calc(100vh - 36px));
    overflow: auto;
    border: 1px solid rgb(245 184 0 / 32%);
    border-radius: 8px;
    background:
        linear-gradient(145deg, rgb(245 184 0 / 8%), transparent 32%),
        var(--color-bg-soft);
    padding: 20px;
    box-shadow: 0 24px 70px rgb(0 0 0 / 56%);
}

.cookie-consent__panel-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
}

.cookie-consent__close {
    display: grid;
    place-items: center;
    width: 36px;
    height: 36px;
    border: 1px solid rgb(154 164 175 / 25%);
    border-radius: 999px;
    background: rgb(255 255 255 / 5%);
    color: var(--color-text);
    cursor: pointer;
}

.cookie-consent__form {
    display: grid;
    gap: 12px;
}

.cookie-consent__toggle {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 13px;
    align-items: start;
    padding: 14px;
    border: 1px solid rgb(154 164 175 / 20%);
    border-radius: 8px;
    background: rgb(255 255 255 / 3%);
}

.cookie-consent__toggle input {
    position: relative;
    width: 44px;
    height: 24px;
    margin-top: 1px;
    appearance: none;
    border: 1px solid rgb(154 164 175 / 32%);
    border-radius: 999px;
    background: rgb(5 8 13 / 90%);
    cursor: pointer;
    transition:
        background-color 160ms ease,
        border-color 160ms ease;
}

.cookie-consent__toggle input::before {
    position: absolute;
    top: 3px;
    left: 3px;
    width: 16px;
    height: 16px;
    border-radius: 999px;
    background: var(--color-muted);
    content: "";
    transition:
        background-color 160ms ease,
        transform 160ms ease;
}

.cookie-consent__toggle input:checked {
    border-color: rgb(245 184 0 / 72%);
    background: rgb(245 184 0 / 18%);
}

.cookie-consent__toggle input:checked::before {
    background: var(--color-accent-strong);
    transform: translateX(20px);
}

.cookie-consent__toggle input:disabled {
    cursor: not-allowed;
    opacity: 0.72;
}

.cookie-consent__toggle span {
    display: grid;
    gap: 4px;
}

.cookie-consent__toggle strong {
    color: var(--color-text);
}

.cookie-consent__toggle small {
    color: var(--color-muted);
    line-height: 1.45;
}

.cookie-consent__toggle.is-locked {
    opacity: 0.88;
}

.card-grid {
    display: grid;
    gap: 14px;
}

.card-grid--reviews {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.card-grid--articles {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.review-carousel {
    min-width: 0;
}

.review-carousel__track {
    display: grid;
    grid-auto-columns: minmax(230px, 31%);
    grid-auto-flow: column;
    gap: 14px;
    overflow-x: auto;
    padding-bottom: 10px;
    scroll-snap-type: x proximity;
}

.review-carousel__track > * {
    scroll-snap-align: start;
}

.review-card,
.article-card,
.release-list,
.lumiri-panel,
.indie-radar,
.topic-panel {
    border: 1px solid rgb(255 255 255 / 12%);
    border-radius: 6px;
    background: linear-gradient(180deg, rgb(17 24 32 / 94%), rgb(9 14 20 / 94%));
    box-shadow: 0 1px 0 rgb(255 255 255 / 4%) inset;
}

.review-card,
.article-card {
    min-width: 0;
    overflow: hidden;
}

.review-card__media,
.article-card__media {
    position: relative;
    aspect-ratio: 16 / 10;
    overflow: hidden;
}

.article-card__media span {
    position: absolute;
    bottom: 10px;
    left: 10px;
    border-radius: 3px;
    background: var(--color-accent);
    color: #1f1600;
    font-size: 0.72rem;
    font-weight: 900;
    line-height: 1;
    padding: 5px 7px;
}

.review-card__body,
.article-card__body {
    display: grid;
    gap: 14px;
    padding: 14px 16px 16px;
}

.review-card h3,
.article-card h3 {
    margin: 0;
    color: var(--color-text);
    font-size: clamp(1rem, 1.35vw, 1.32rem);
    line-height: 1.12;
}

.preview-card__excerpt {
    display: -webkit-box;
    overflow: hidden;
    margin: 0;
    color: var(--color-muted);
    font-size: 0.9rem;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
}

.tech-review-showcase {
    display: grid;
    gap: 20px;
    border: 1px solid rgb(255 255 255 / 12%);
    border-radius: 6px;
    background:
        linear-gradient(135deg, rgb(34 211 238 / 10%), rgb(245 184 0 / 7%) 36%, rgb(17 24 32 / 96%) 72%),
        linear-gradient(180deg, rgb(17 24 32 / 96%), rgb(7 11 16 / 96%));
    box-shadow: 0 1px 0 rgb(255 255 255 / 5%) inset;
    padding: clamp(18px, 3vw, 26px);
}

.tech-review-showcase__layout {
    display: grid;
    grid-template-columns: minmax(0, 1.25fr) minmax(260px, 0.75fr);
    gap: 16px;
}

.tech-review-showcase__lead,
.tech-review-mini {
    border: 1px solid rgb(255 255 255 / 12%);
    border-radius: 6px;
    background: rgb(5 8 13 / 48%);
    color: var(--color-text);
    overflow: hidden;
}

.tech-review-showcase__lead {
    display: grid;
    grid-template-columns: minmax(220px, 42%) minmax(0, 1fr);
    min-height: 260px;
}

.tech-review-showcase__media {
    position: relative;
    min-height: 260px;
    overflow: hidden;
}

.tech-review-showcase__media img,
.tech-review-mini .thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.tech-review-showcase__content {
    display: grid;
    align-content: center;
    gap: 16px;
    padding: clamp(18px, 3vw, 30px);
}

.tech-review-showcase__content strong {
    color: var(--color-text);
    font-size: clamp(1.55rem, 2.6vw, 2.45rem);
    line-height: 1.02;
}

.tech-review-showcase__excerpt {
    color: #d9e2ea;
    line-height: 1.6;
}

.tech-review-showcase__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.tech-review-showcase__meta span,
.tech-review-mini small {
    border: 1px solid rgb(255 255 255 / 18%);
    border-radius: 4px;
    color: #dce6ef;
    font-size: 0.74rem;
    font-style: normal;
    font-weight: 900;
    line-height: 1;
    padding: 7px 9px;
    text-transform: uppercase;
}

.tech-review-showcase__list {
    display: grid;
    gap: 12px;
}

.tech-review-mini {
    display: grid;
    grid-template-columns: 92px minmax(0, 1fr);
    gap: 13px;
    min-height: 104px;
    padding: 10px;
}

.tech-review-mini .thumb {
    width: 92px;
    min-height: 84px;
}

.tech-review-mini > span:last-child {
    display: grid;
    align-content: center;
    gap: 8px;
}

.tech-review-mini strong {
    color: var(--color-text);
    line-height: 1.15;
}

.tech-review-mini small {
    width: fit-content;
    color: var(--color-accent-strong);
    padding: 0;
    border: 0;
}

.tech-review-mini em {
    color: var(--color-muted);
    font-size: 0.82rem;
    font-style: normal;
}

.article-card h3 {
    font-size: clamp(0.98rem, 1.2vw, 1.1rem);
}

.article-card small {
    color: var(--color-muted);
}

.score-corner {
    --score-step-accent: var(--color-accent);

    position: absolute;
    top: 8px;
    left: 8px;
    display: inline-flex;
    min-width: 50px;
    min-height: 34px;
    align-items: center;
    justify-content: center;
    gap: 2px;
    padding: 0 9px;
    border: 1px solid color-mix(in srgb, var(--score-step-accent) 88%, white 8%);
    border-radius: 5px;
    background:
        linear-gradient(
            180deg,
            color-mix(in srgb, var(--score-step-accent) 78%, white 18%),
            color-mix(in srgb, var(--score-step-accent) 92%, black 8%)
        );
    box-shadow:
        0 10px 22px rgb(0 0 0 / 34%),
        0 0 0 1px rgb(255 255 255 / 20%) inset;
    color: #1f1600;
    font-size: 0.9rem;
    font-variant-numeric: tabular-nums;
    font-weight: 950;
    line-height: 1;
}

.score-corner::after {
    content: "/10";
    color: rgb(31 22 0 / 72%);
    font-size: 0.58rem;
    font-weight: 900;
    line-height: 1;
}

.score-corner.score-corner--rating-step-1 {
    --score-step-accent: #ef4444;
}

.score-corner.score-corner--rating-step-2 {
    --score-step-accent: #f97316;
}

.score-corner.score-corner--rating-step-3 {
    --score-step-accent: #f59e0b;
}

.score-corner.score-corner--rating-step-4 {
    --score-step-accent: #facc15;
}

.score-corner.score-corner--rating-step-5 {
    --score-step-accent: #84cc16;
}

.score-corner.score-corner--rating-step-6 {
    --score-step-accent: #38bdf8;
}

.score-corner.score-corner--rating-step-7 {
    --score-step-accent: #a78bfa;
}

.score-corner.score-corner--rating-step-8 {
    --score-step-accent: #f472b6;
}

.score-corner.score-corner--rating-step-9 {
    --score-step-accent: #c084fc;
}

.score-corner.score-corner--rating-step-10 {
    --score-step-accent: #fbbf24;
}

.meta-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    color: var(--color-muted);
    font-size: 0.78rem;
}

.meta-row span {
    min-height: 24px;
    padding: 6px 8px;
}

.release-list,
.lumiri-panel,
.indie-radar {
    display: grid;
    gap: 15px;
    padding: 18px;
}

.release-item {
    grid-template-columns: 76px minmax(0, 1fr) auto;
    padding-bottom: 12px;
    border-bottom: 1px solid rgb(255 255 255 / 8%);
}

.release-item time {
    margin: 0;
    white-space: nowrap;
}

.lumiri-panel p,
.lumiri-panel small,
.site-footer p {
    margin: 0;
    color: var(--color-muted);
}

.feature-heading {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 24px;
}

.feature-heading h2 {
    margin: 0;
    color: var(--color-text);
    font-size: 1.25rem;
    line-height: 1.1;
    text-transform: uppercase;
}

.feature-heading p {
    max-width: 640px;
    margin: 8px 0 0;
    color: var(--color-muted);
}

.feature-heading a {
    flex: 0 0 auto;
    padding-top: 4px;
}

.content-label {
    width: fit-content;
    border-radius: 3px;
    background: var(--color-accent);
    color: #1f1600;
    font-size: 0.72rem;
    font-weight: 900;
    line-height: 1;
    padding: 5px 7px;
    text-transform: uppercase;
}

.indie-list {
    display: grid;
    gap: 13px;
}

.indie-radar {
    background:
        linear-gradient(120deg, rgb(10 63 70 / 46%), rgb(8 13 19 / 96%) 45%, rgb(17 24 32 / 96%)),
        var(--color-surface);
}

.indie-radar__layout {
    display: grid;
    grid-template-columns: minmax(0, 1.25fr) minmax(260px, 0.75fr);
    gap: 18px;
}

.indie-radar__lead {
    display: grid;
    gap: 12px;
}

.indie-radar__lead .media-art {
    position: relative;
    min-height: 210px;
    overflow: hidden;
    border: 1px solid rgb(255 255 255 / 10%);
    border-radius: 5px;
}

.indie-radar__lead strong {
    max-width: 680px;
    color: var(--color-text);
    font-size: clamp(1.4rem, 2.6vw, 2.1rem);
    line-height: 1.05;
}

.indie-radar__lead small {
    color: var(--color-muted);
}

.indie-radar__items {
    display: grid;
    align-content: start;
    gap: 13px;
}

.indie-item {
    grid-template-columns: 72px minmax(0, 1fr);
    padding-top: 12px;
    border-top: 1px solid rgb(255 255 255 / 8%);
}

.lumiri-panel {
    position: relative;
    overflow: hidden;
    background:
        linear-gradient(145deg, rgb(11 77 74 / 38%), rgb(8 13 19 / 96%) 48%, rgb(28 23 15 / 78%)),
        var(--color-surface);
}

.lumiri-panel strong {
    color: var(--color-text);
    font-size: 1.08rem;
    line-height: 1.25;
}

.weekly-buff {
    display: grid;
    gap: 12px;
}

.weekly-buff h3 {
    margin: 0;
    color: var(--color-text);
    font-size: 1.18rem;
    line-height: 1.18;
}

.weekly-buff__body {
    display: grid;
    gap: 10px;
    color: var(--color-muted);
    font-size: 0.95rem;
    line-height: 1.65;
}

.weekly-buff__body p,
.weekly-buff__body ul,
.weekly-buff__body ol {
    margin: 0;
}

.weekly-buff__body ul,
.weekly-buff__body ol {
    display: grid;
    gap: 6px;
    padding-left: 1.15rem;
}

.weekly-buff__body strong {
    font-size: inherit;
}

.weekly-buff__updated {
    color: var(--color-muted);
    font-size: 0.78rem;
}

.soundcloud-link {
    display: inline-flex;
    width: fit-content;
    align-items: center;
    gap: 8px;
    border-bottom: 1px solid rgb(245 184 0 / 60%);
    color: var(--color-accent);
    font-size: 0.9rem;
    font-weight: 900;
}

.soundcloud-link::before {
    width: 10px;
    height: 10px;
    content: "";
    border-radius: 50%;
    background: var(--color-accent);
    box-shadow: 14px 0 0 rgb(245 184 0 / 44%);
}

.lumiri-panel__signal {
    position: relative;
    min-height: 118px;
    overflow: hidden;
    border: 1px solid rgb(255 255 255 / 10%);
    border-radius: 5px;
    background:
        linear-gradient(135deg, rgb(45 212 191 / 20%), rgb(245 184 0 / 8%) 45%, rgb(255 255 255 / 0)),
        repeating-linear-gradient(0deg, rgb(255 255 255 / 8%) 0 1px, transparent 1px 12px),
        linear-gradient(135deg, #102f32, #0c121b 64%, #05080d);
}

.lumiri-panel__signal::before {
    position: absolute;
    inset: 26px 22px auto;
    height: 2px;
    content: "";
    background: linear-gradient(90deg, transparent, var(--color-accent), transparent);
}

.topic-rail {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
    padding-block: 26px 32px;
}

.topic-panel {
    min-height: 210px;
    padding: 16px;
}

.topic-panel header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 14px;
}

.topic-panel h2 {
    margin: 0;
    font-size: 1.12rem;
    line-height: 1.1;
    text-transform: uppercase;
}

.topic-panel header a {
    color: var(--color-accent);
    font-size: 0.78rem;
    white-space: nowrap;
}

.topic-panel li a {
    color: #e8edf3;
    font-size: inherit;
    white-space: normal;
}

.topic-panel ul {
    display: grid;
    gap: 10px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.topic-panel li {
    color: #e8edf3;
    font-weight: 700;
    line-height: 1.25;
}

.topic-panel__item {
    display: grid;
    grid-template-columns: clamp(50px, 30%, 78px) minmax(0, 1fr);
    gap: 11px;
    align-items: center;
    min-height: 60px;
}

.topic-panel__thumb {
    position: relative;
    display: block;
    width: 100%;
    aspect-ratio: 4 / 3;
    overflow: hidden;
    border: 1px solid rgb(255 255 255 / 12%);
    border-radius: 4px;
    background-color: var(--color-bg-soft);
}

.topic-panel__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.topic-panel__item span:last-child {
    display: -webkit-box;
    min-width: 0;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}

.topic-panel__item:hover span:last-child,
.topic-panel__item:focus-visible span:last-child {
    color: var(--color-accent-strong);
}

.topic-panel--guides {
    background:
        linear-gradient(180deg, rgb(22 33 58 / 70%), rgb(8 13 19 / 94%)),
        var(--color-surface);
}

.topic-panel--hardware {
    background:
        linear-gradient(180deg, rgb(74 38 27 / 70%), rgb(8 13 19 / 94%)),
        var(--color-surface);
}

.topic-panel--linux {
    background:
        linear-gradient(180deg, rgb(10 63 70 / 70%), rgb(8 13 19 / 94%)),
        var(--color-surface);
}

.topic-panel--indie {
    background:
        linear-gradient(180deg, rgb(29 76 52 / 70%), rgb(8 13 19 / 94%)),
        var(--color-surface);
}

.site-footer {
    border-top: 1px solid rgb(255 255 255 / 12%);
    background:
        radial-gradient(circle at 18% 0, rgb(245 184 0 / 10%), transparent 30%),
        linear-gradient(180deg, #0a1017 0%, #060a10 48%, #03060a 100%);
    box-shadow: 0 -1px 0 rgb(245 184 0 / 8%) inset;
}

.site-footer__inner {
    display: grid;
    gap: 24px;
    padding-block: clamp(34px, 4vw, 58px) 24px;
}

.site-footer__grid {
    display: grid;
    grid-template-columns: minmax(260px, 1.15fr) minmax(280px, 1.35fr) minmax(180px, 0.85fr) minmax(220px, 1fr);
    gap: clamp(24px, 3.6vw, 54px);
    align-items: start;
}

.site-footer__section {
    display: grid;
    min-width: 0;
    align-content: start;
    gap: 12px;
}

.site-footer__section--quick-links {
    grid-column: span 2;
}

.site-footer__section--brand {
    max-width: 380px;
}

.site-footer h2 {
    margin: 0;
    color: var(--color-text);
    font-size: 0.78rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.site-footer h3 {
    margin: 0;
    color: var(--color-muted);
    font-size: 0.76rem;
    font-weight: 900;
    text-transform: uppercase;
}

.site-footer__section--brand img {
    display: block;
    width: auto;
    max-width: 228px;
    max-height: 58px;
    height: auto;
    margin-bottom: 4px;
    object-fit: contain;
}

.site-footer p {
    max-width: 42rem;
    line-height: 1.62;
}

.site-footer__link-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 7px 18px;
}

.site-footer__link,
.site-footer__bottom span,
.site-footer p {
    color: var(--color-muted);
}

.site-footer__link {
    min-width: 0;
    overflow-wrap: anywhere;
    font-size: 0.92rem;
    line-height: 1.3;
    transition: color 160ms ease, border-color 160ms ease, background 160ms ease;
}

.site-footer a.site-footer__link:hover,
.site-footer a.site-footer__link:focus-visible,
.footer-partner-list a:hover,
.footer-partner-list a:focus-visible {
    color: var(--color-text);
}

.site-footer__link--placeholder {
    opacity: 0.58;
}

.social-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.social-row .site-footer__link {
    display: inline-flex;
    min-height: 34px;
    align-items: center;
    border: 1px solid rgb(255 255 255 / 12%);
    border-radius: 6px;
    background: rgb(255 255 255 / 4%);
    padding: 6px 10px;
    font-size: 0.86rem;
}

.social-row a.site-footer__link:hover,
.social-row a.site-footer__link:focus-visible {
    border-color: rgb(245 184 0 / 48%);
    background: rgb(245 184 0 / 8%);
}

.social-row span[aria-disabled="true"] {
    cursor: not-allowed;
}

.footer-partner-group,
.footer-partner-list {
    display: grid;
    gap: 9px;
}

.footer-partner-group + .footer-partner-group {
    margin-top: 4px;
}

.footer-partner-list a {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    gap: 8px;
    min-width: 0;
    color: var(--color-muted);
    font-size: 0.9rem;
}

.footer-partner-list img {
    width: 26px;
    max-width: 26px;
    height: 26px;
    max-height: 26px;
    margin: 0;
    border-radius: 4px;
    object-fit: contain;
    background: rgb(255 255 255 / 8%);
}

.footer-partner-list span {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.site-footer__bottom {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 10px 20px;
    border-top: 1px solid rgb(255 255 255 / 9%);
    padding-top: 18px;
    font-size: 0.82rem;
}

.media-art {
    overflow: hidden;
    background:
        linear-gradient(135deg, rgb(255 255 255 / 18%), rgb(255 255 255 / 0) 34%),
        linear-gradient(135deg, #21334a, #101720 52%, #05080d);
}

.media-art::before,
.media-art::after {
    position: absolute;
    content: "";
}

.media-art::before {
    inset: 12% 10% auto auto;
    width: 38%;
    aspect-ratio: 1;
    border: 1px solid rgb(255 255 255 / 14%);
    transform: rotate(18deg);
}

.media-art::after {
    right: 14%;
    bottom: 12%;
    width: 42%;
    height: 14%;
    border-radius: 999px;
    background: rgb(255 255 255 / 10%);
    filter: blur(18px);
}

.portal-hero__media.media-art::before {
    top: 8%;
    right: 8%;
    width: 36%;
    border-color: rgb(245 184 0 / 26%);
}

.media-art--kingdom {
    background:
        linear-gradient(120deg, rgb(14 20 28 / 14%), rgb(6 8 10 / 72) 70%),
        linear-gradient(135deg, #69706b 0%, #8a6b45 28%, #1f3f57 56%, #111820 82%);
}

.media-art--ring,
.thumb--ring {
    background:
        linear-gradient(135deg, rgb(245 184 0 / 20%), rgb(255 255 255 / 0)),
        linear-gradient(135deg, #5b3b16, #111820 58%, #05110d);
}

.media-art--doom,
.thumb--ember {
    background:
        linear-gradient(135deg, rgb(239 68 68 / 24%), rgb(255 255 255 / 0)),
        linear-gradient(135deg, #5a1616, #2b1b14 54%, #07090d);
}

.media-art--stellar,
.thumb--blue {
    background:
        linear-gradient(135deg, rgb(34 211 238 / 20%), rgb(255 255 255 / 0)),
        linear-gradient(135deg, #123b57, #16213b 58%, #07090d);
}

.media-art--guide,
.thumb--sand,
.thumb--fable {
    background:
        linear-gradient(135deg, rgb(255 255 255 / 18%), rgb(255 255 255 / 0)),
        linear-gradient(135deg, #65523a, #25384a 56%, #0a0d12);
}

.media-art--indie,
.thumb--indie,
.thumb--green {
    background:
        linear-gradient(135deg, rgb(34 197 94 / 20%), rgb(255 255 255 / 0)),
        linear-gradient(135deg, #164e36, #12313a 56%, #07090d);
}

.media-art--story,
.thumb--device,
.thumb--strand {
    background:
        linear-gradient(135deg, rgb(255 255 255 / 14%), rgb(255 255 255 / 0)),
        linear-gradient(135deg, #46312a, #131e28 58%, #07090d);
}

.media-art--preview,
.thumb--steel,
.thumb--ghost {
    background:
        linear-gradient(135deg, rgb(34 197 94 / 18%), rgb(255 255 255 / 0)),
        linear-gradient(135deg, #1f4936, #17212b 62%, #07090d);
}

.media-art--hardware,
.thumb--dune {
    background:
        linear-gradient(135deg, rgb(245 184 0 / 16%), rgb(255 255 255 / 0)),
        linear-gradient(135deg, #4c3c2c, #20252d 54%, #07090d);
}

.thumb--kingdom {
    background:
        linear-gradient(135deg, rgb(245 184 0 / 16%), rgb(255 255 255 / 0)),
        linear-gradient(135deg, #6d6d58, #2e4554 56%, #0b1017);
}

.site-shell {
    width: min(1120px, calc(100% - 32px));
    margin: 0 auto;
    padding: 48px 0;
}

.hero {
    border: 1px solid var(--color-surface-border);
    border-radius: 8px;
    background: linear-gradient(135deg, var(--color-surface), var(--color-bg-soft));
    padding: clamp(32px, 6vw, 72px);
}

.maintenance-hero {
    max-width: 860px;
    margin-inline: auto;
    background:
        linear-gradient(135deg, rgb(245 184 0 / 16%), rgb(239 68 68 / 10%) 46%, rgb(255 255 255 / 0)),
        linear-gradient(180deg, rgb(17 24 32 / 96%), rgb(8 13 19 / 96%));
}

body.page-maintenance {
    min-height: 100vh;
    background: #05080d;
    color: #f5f7fa;
}

.maintenance-page {
    position: relative;
    isolation: isolate;
    min-height: 100vh;
    display: grid;
    align-items: center;
    overflow: hidden;
    --maintenance-accent: #00d1ff;
    --maintenance-accent-strong: #f5b800;
    --maintenance-panel-start: rgb(13 20 31 / 90%);
    --maintenance-panel-end: rgb(6 10 17 / 94%);
    --maintenance-status-bg: rgb(0 209 255 / 12%);
    --maintenance-status-border: rgb(0 209 255 / 38%);
    background:
        linear-gradient(90deg, rgb(5 8 13 / 98%) 0%, rgb(5 8 13 / 86%) 38%, rgb(5 8 13 / 36%) 72%, rgb(5 8 13 / 18%) 100%),
        linear-gradient(180deg, rgb(5 8 13 / 30%) 0%, rgb(5 8 13 / 78%) 100%),
        var(--maintenance-background-image);
    background-position: center, center, right center;
    background-size: cover;
    padding: 48px 24px;
}

.maintenance-page--launch-countdown {
    --maintenance-accent: #ffcc00;
    --maintenance-accent-strong: #00d1ff;
    --maintenance-status-bg: rgb(255 204 0 / 13%);
    --maintenance-status-border: rgb(255 204 0 / 42%);
}

.maintenance-page--coming-soon {
    --maintenance-accent: #22c55e;
    --maintenance-accent-strong: #00d1ff;
    --maintenance-status-bg: rgb(34 197 94 / 13%);
    --maintenance-status-border: rgb(34 197 94 / 40%);
}

.maintenance-page--custom {
    --maintenance-accent: #f472b6;
    --maintenance-accent-strong: #f5b800;
    --maintenance-status-bg: rgb(244 114 182 / 13%);
    --maintenance-status-border: rgb(244 114 182 / 38%);
}

.maintenance-page::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: -1;
    background:
        linear-gradient(180deg, transparent 0%, rgb(5 8 13 / 22%) 45%, rgb(5 8 13 / 88%) 100%),
        linear-gradient(90deg, rgb(5 8 13 / 42%) 0%, transparent 42%, rgb(5 8 13 / 24%) 100%);
}

.maintenance-effects {
    position: absolute;
    inset: 0;
    z-index: -1;
    overflow: hidden;
    pointer-events: none;
}

.maintenance-effects span {
    position: absolute;
    display: block;
}

.maintenance-effects__grid {
    inset: 0;
    background:
        repeating-linear-gradient(90deg, color-mix(in srgb, var(--maintenance-accent) 34%, transparent) 0 1px, transparent 1px 88px),
        repeating-linear-gradient(0deg, rgb(245 184 0 / 5%) 0 1px, transparent 1px 72px);
    mask-image: linear-gradient(90deg, #000 0%, rgb(0 0 0 / 80%) 48%, transparent 100%);
    opacity: 0.78;
}

.maintenance-effects__scanline {
    inset: 0;
    background: repeating-linear-gradient(180deg, transparent 0 8px, rgb(255 255 255 / 4%) 8px 9px);
    mix-blend-mode: screen;
    opacity: 0.28;
    animation: maintenance-scan 9s linear infinite;
}

.maintenance-effects__trace {
    width: 42%;
    height: 150%;
    top: -25%;
    transform: rotate(18deg);
    background:
        linear-gradient(90deg, transparent 0%, color-mix(in srgb, var(--maintenance-accent) 28%, transparent) 48%, transparent 100%);
    filter: blur(18px);
    opacity: 0.42;
}

.maintenance-effects__trace--one {
    right: 7%;
    animation: maintenance-trace 13s ease-in-out infinite;
}

.maintenance-effects__trace--two {
    right: -18%;
    background:
        linear-gradient(90deg, transparent 0%, color-mix(in srgb, var(--maintenance-accent-strong) 24%, transparent) 48%, transparent 100%);
    animation: maintenance-trace 17s ease-in-out infinite reverse;
}

.maintenance-page__content {
    position: relative;
    z-index: 1;
    width: min(1180px, 100%);
    margin: 0 auto;
}

.maintenance-panel {
    position: relative;
    overflow: hidden;
    width: min(560px, 100%);
    border: 1px solid rgb(255 255 255 / 16%);
    border-radius: 8px;
    background:
        linear-gradient(180deg, var(--maintenance-panel-start), var(--maintenance-panel-end)),
        linear-gradient(115deg, color-mix(in srgb, var(--maintenance-accent) 12%, transparent), transparent 46%),
        rgb(5 8 13 / 92%);
    box-shadow:
        0 28px 80px rgb(0 0 0 / 48%),
        0 0 42px color-mix(in srgb, var(--maintenance-accent) 14%, transparent);
    padding: 34px;
    backdrop-filter: blur(14px);
}

.maintenance-panel__edge {
    position: absolute;
    inset: 0 0 auto;
    height: 2px;
    background:
        linear-gradient(90deg, transparent 0%, var(--maintenance-accent) 28%, var(--maintenance-accent-strong) 52%, transparent 100%);
    opacity: 0.86;
    animation: maintenance-pulse 4s ease-in-out infinite;
}

.maintenance-panel__logo {
    display: block;
    width: min(360px, 100%);
    height: auto;
    margin-bottom: 26px;
    filter: drop-shadow(0 12px 22px rgb(0 0 0 / 38%));
}

.maintenance-panel__status {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin: 0 0 18px;
    border: 1px solid var(--maintenance-status-border);
    border-radius: 999px;
    background: var(--maintenance-status-bg);
    color: #dff8ff;
    font-size: 0.82rem;
    font-weight: 800;
    padding: 7px 12px 7px 8px;
    box-shadow: 0 0 26px color-mix(in srgb, var(--maintenance-accent) 13%, transparent);
}

.maintenance-panel__status img {
    width: 24px;
    height: 24px;
    object-fit: contain;
}

.maintenance-panel h1 {
    max-width: 520px;
    margin: 0;
    color: #ffffff;
    font-size: 4rem;
    line-height: 0.96;
}

.maintenance-panel__lead {
    margin: 22px 0 0;
    color: #d8e0eb;
    font-size: 1.14rem;
    line-height: 1.65;
}

.maintenance-signal {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 8px;
    width: min(260px, 72%);
    margin-top: 22px;
}

.maintenance-signal span {
    height: 4px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--maintenance-accent) 62%, rgb(255 255 255 / 14%));
    box-shadow: 0 0 18px color-mix(in srgb, var(--maintenance-accent) 32%, transparent);
    opacity: 0.5;
    animation: maintenance-signal 2.6s ease-in-out infinite;
}

.maintenance-signal span:nth-child(2) {
    animation-delay: 0.12s;
}

.maintenance-signal span:nth-child(3) {
    animation-delay: 0.24s;
}

.maintenance-signal span:nth-child(4) {
    animation-delay: 0.36s;
}

.maintenance-signal span:nth-child(5) {
    animation-delay: 0.48s;
}

.maintenance-panel__note {
    margin: 22px 0 0;
    color: #9fb0c2;
    font-size: 0.95rem;
    line-height: 1.55;
}

.maintenance-countdown {
    display: grid;
    gap: 16px;
    margin-top: 28px;
    border: 1px solid rgb(255 255 255 / 14%);
    border-radius: 8px;
    background:
        linear-gradient(135deg, color-mix(in srgb, var(--maintenance-accent) 10%, transparent), transparent 58%),
        rgb(255 255 255 / 6%);
    padding: 16px;
    box-shadow: inset 0 0 0 1px rgb(255 255 255 / 3%);
}

.maintenance-countdown__date {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 12px;
    align-items: baseline;
    margin: 0;
}

.maintenance-countdown__date span {
    color: #9fb0c2;
    font-size: 0.78rem;
    font-weight: 800;
    text-transform: uppercase;
}

.maintenance-countdown__date time {
    color: #ffffff;
    font-weight: 800;
}

.maintenance-countdown__grid {
    display: grid;
    gap: 10px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.maintenance-countdown__grid span {
    display: grid;
    gap: 4px;
    min-width: 0;
    border: 1px solid color-mix(in srgb, var(--maintenance-accent) 28%, transparent);
    border-radius: 7px;
    background: rgb(4 9 16 / 68%);
    padding: 12px 8px;
    text-align: center;
    box-shadow: 0 0 18px color-mix(in srgb, var(--maintenance-accent) 8%, transparent);
}

.maintenance-countdown__grid strong {
    color: #ffffff;
    font-size: 1.55rem;
    line-height: 1;
}

.maintenance-countdown__grid small {
    color: #9fb0c2;
    font-size: 0.72rem;
    font-weight: 800;
    text-transform: uppercase;
}

.maintenance-countdown__status {
    margin: 0;
    color: #9fb0c2;
    font-size: 0.88rem;
}

.maintenance-countdown--date-only {
    padding-block: 14px;
}

@keyframes maintenance-scan {
    0% {
        transform: translateY(-18px);
    }

    100% {
        transform: translateY(18px);
    }
}

@keyframes maintenance-trace {
    0%,
    100% {
        opacity: 0.22;
        translate: -18px 0;
    }

    48% {
        opacity: 0.5;
        translate: 26px 0;
    }
}

@keyframes maintenance-pulse {
    0%,
    100% {
        opacity: 0.54;
    }

    50% {
        opacity: 1;
    }
}

@keyframes maintenance-signal {
    0%,
    100% {
        opacity: 0.38;
        transform: scaleX(0.72);
        transform-origin: left center;
    }

    46% {
        opacity: 1;
        transform: scaleX(1);
    }
}

@media (max-width: 820px) {
    .maintenance-page {
        align-items: end;
        background:
            linear-gradient(180deg, rgb(5 8 13 / 44%) 0%, rgb(5 8 13 / 84%) 46%, rgb(5 8 13 / 98%) 100%),
            var(--maintenance-background-image);
        background-position: center top;
        background-size: cover;
        padding: 32px 16px;
    }

    .maintenance-page::after {
        opacity: 0.55;
        mask-image: linear-gradient(180deg, transparent 0%, #000 42%, #000 100%);
    }

    .maintenance-effects__grid {
        opacity: 0.48;
        mask-image: linear-gradient(180deg, transparent 0%, #000 42%, #000 100%);
    }

    .maintenance-effects__trace {
        width: 70%;
        right: -28%;
    }

    .maintenance-panel {
        padding: 24px;
    }

    .maintenance-panel h1 {
        font-size: 2.7rem;
        line-height: 1;
    }

    .maintenance-panel__lead {
        font-size: 1.02rem;
    }
}

@media (max-width: 520px) {
    .maintenance-countdown__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .maintenance-panel h1 {
        font-size: 2.25rem;
    }
}

@media (prefers-reduced-motion: reduce) {
    .maintenance-effects__scanline,
    .maintenance-effects__trace,
    .maintenance-panel__edge,
    .maintenance-signal span {
        animation: none;
    }

    .maintenance-countdown__grid strong {
        transition: none;
    }
}

.eyebrow {
    margin: 0 0 12px;
    color: var(--color-accent);
    font-size: 0.78rem;
    font-weight: 800;
    text-transform: uppercase;
}

.hero h1 {
    max-width: 760px;
    margin: 0;
    font-size: clamp(2.3rem, 6vw, 5rem);
    line-height: 1;
}

.lead {
    max-width: 720px;
    margin: 24px 0 0;
    color: var(--color-muted);
    font-size: clamp(1rem, 2vw, 1.25rem);
}

.account-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 28px;
}

.account-actions__link {
    display: inline-flex;
    min-height: 42px;
    align-items: center;
    justify-content: center;
    border: 1px solid rgb(255 255 255 / 22%);
    border-radius: 4px;
    background: rgb(255 255 255 / 3%);
    color: var(--color-text);
    font-size: 0.84rem;
    font-weight: 900;
    line-height: 1;
    padding: 12px 18px;
    text-transform: uppercase;
    transition:
        background-color 160ms ease,
        border-color 160ms ease,
        color 160ms ease,
        transform 160ms ease;
}

.account-actions__link:hover,
.account-actions__link:focus-visible {
    border-color: rgb(245 184 0 / 55%);
    color: var(--color-accent-strong);
    outline: none;
    transform: translateY(-1px);
}

.account-actions__primary {
    border-color: var(--color-accent);
    background: linear-gradient(180deg, var(--color-accent-strong), var(--color-accent));
    color: #221700;
}

.account-actions__primary:hover,
.account-actions__primary:focus-visible {
    color: #221700;
}

.search-form {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
    max-width: 720px;
    margin-top: 30px;
}

.search-form input {
    min-width: 0;
    border: 1px solid var(--color-surface-border);
    border-radius: 6px;
    background: var(--color-bg);
    color: var(--color-text);
    padding: 13px 14px;
}

.search-form button {
    border: 0;
    border-radius: 6px;
    background: var(--color-accent);
    color: #1f1600;
    cursor: pointer;
    font-weight: 900;
    padding: 13px 18px;
}

.search-suggestions {
    grid-column: 1 / -1;
}

.search-suggestions__list {
    display: grid;
    gap: 8px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.search-suggestions__list a {
    display: grid;
    gap: 4px;
    border: 1px solid rgb(255 255 255 / 14%);
    border-radius: 6px;
    background: rgb(5 8 13 / 88%);
    color: var(--color-text);
    padding: 10px 12px;
}

.search-suggestions__list a:hover,
.search-suggestions__list a:focus-visible {
    border-color: rgb(245 184 0 / 55%);
    background: rgb(245 184 0 / 10%);
    outline: none;
}

.search-suggestions__list strong,
.search-suggestions__list span {
    min-width: 0;
    overflow-wrap: anywhere;
}

.lumiri-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 28px;
}

.lumiri-actions__button {
    width: auto;
    min-width: 170px;
    justify-content: center;
}

.lumiri-actions__button--secondary {
    border-color: rgb(245 184 0 / 40%);
    background: rgb(245 184 0 / 8%);
    color: var(--color-text);
}

.lumiri-actions__button--secondary:hover,
.lumiri-actions__button--secondary:focus-visible {
    border-color: rgb(245 184 0 / 68%);
    background: rgb(245 184 0 / 15%);
}

.login-form {
    display: grid;
    gap: 14px;
    max-width: 420px;
    margin-top: 30px;
}

.login-form label {
    color: var(--color-muted);
    font-size: 0.9rem;
    font-weight: 700;
}

.login-form input {
    width: 100%;
    border: 1px solid rgb(255 255 255 / 16%);
    border-radius: 6px;
    background: rgb(5 8 13 / 88%);
    color: var(--color-text);
    outline: none;
    padding: 13px 14px;
    transition:
        border-color 160ms ease,
        box-shadow 160ms ease,
        background-color 160ms ease;
}

.login-form input:focus {
    border-color: var(--color-accent);
    background: rgb(5 8 13 / 100%);
    box-shadow: 0 0 0 3px rgb(245 184 0 / 16%);
}

.login-form button {
    width: fit-content;
    border: 0;
    border-radius: 6px;
    background: linear-gradient(180deg, var(--color-accent-strong), var(--color-accent));
    color: #1f1600;
    cursor: pointer;
    font-weight: 800;
    padding: 13px 20px;
    transition:
        box-shadow 160ms ease,
        transform 160ms ease;
}

.login-form button:hover,
.login-form button:focus-visible {
    box-shadow: 0 12px 24px rgb(245 184 0 / 18%);
    transform: translateY(-1px);
}

.auth-shell {
    position: relative;
    isolation: isolate;
    display: grid;
    align-content: center;
    width: min(100% - 32px, 560px);
    min-height: 100vh;
    gap: 16px;
    margin: 0 auto;
    padding: 48px 0;
}

.auth-shell::before {
    position: fixed;
    inset: 0;
    z-index: 0;
    background:
        linear-gradient(90deg, rgb(5 8 13 / 94%) 0%, rgb(5 8 13 / 84%) 36%, rgb(5 8 13 / 46%) 68%, rgb(5 8 13 / 68%) 100%),
        linear-gradient(180deg, rgb(5 8 13 / 62%) 0%, rgb(5 8 13 / 18%) 48%, rgb(5 8 13 / 78%) 100%),
        url("/images/auth/lumiri-nav-login-bg.webp") center right / cover no-repeat;
    content: "";
    pointer-events: none;
}

.auth-shell > * {
    position: relative;
    z-index: 1;
}

.auth-back-link {
    width: fit-content;
    border: 1px solid rgb(255 255 255 / 14%);
    border-radius: 999px;
    background: rgb(255 255 255 / 4%);
    color: var(--color-muted);
    font-size: 0.82rem;
    font-weight: 800;
    padding: 9px 13px;
    text-transform: uppercase;
    transition:
        border-color 160ms ease,
        color 160ms ease,
        transform 160ms ease;
}

.auth-back-link:hover,
.auth-back-link:focus-visible {
    border-color: rgb(245 184 0 / 55%);
    color: var(--color-accent-strong);
    outline: none;
    transform: translateY(-1px);
}

.auth-card {
    position: relative;
    overflow: hidden;
    width: 100%;
    border: 1px solid rgb(255 255 255 / 14%);
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgb(245 184 0 / 8%), transparent 38%),
        linear-gradient(180deg, rgb(17 24 32 / 98%), rgb(8 13 19 / 98%));
    box-shadow: 0 24px 70px rgb(0 0 0 / 42%);
    padding: 38px;
}

.auth-card::before {
    position: absolute;
    inset: 0 0 auto;
    height: 3px;
    background: linear-gradient(90deg, var(--color-accent), transparent 72%);
    content: "";
}

.auth-card > * {
    position: relative;
}

.auth-card h1 {
    margin: 0;
    color: #fff;
    font-size: clamp(2rem, 6vw, 2.8rem);
    line-height: 1.05;
}

.auth-card .lead {
    margin-top: 14px;
    font-size: 1rem;
}

.auth-card .login-form {
    max-width: none;
}

.auth-alert {
    border: 1px solid rgb(239 68 68 / 42%);
    border-radius: 8px;
    background: rgb(239 68 68 / 10%);
    color: #fecaca;
    font-weight: 700;
    margin: 22px 0 0;
    padding: 12px 14px;
}

.auth-note {
    border-top: 1px solid rgb(255 255 255 / 8%);
    color: var(--color-muted);
    font-size: 0.9rem;
    margin: 28px 0 0;
    padding-top: 18px;
}

.redaktion-logo-preview {
    display: grid;
    gap: 8px;
    max-width: 360px;
    border: 1px solid var(--color-surface-border);
    border-radius: 8px;
    background: var(--color-bg);
    padding: 14px;
}

.redaktion-logo-preview span {
    color: var(--color-muted);
    font-size: 0.82rem;
    font-weight: 800;
    text-transform: uppercase;
}

.redaktion-logo-preview img {
    width: min(100%, 260px);
    height: auto;
}

.redaktion-shell {
    display: grid;
    grid-template-columns: 260px minmax(0, 1fr);
    min-height: 100vh;
    background: var(--color-bg);
}

.redaktion-sidebar {
    padding: 24px;
    border-right: 1px solid var(--color-surface-border);
    background: var(--color-bg-soft);
}

.redaktion-brand {
    display: inline-flex;
    align-items: center;
    margin-bottom: 26px;
    color: var(--color-accent-strong);
    font-size: 1.1rem;
    font-weight: 950;
    text-transform: uppercase;
}

.redaktion-brand img {
    display: block;
    width: min(100%, 178px);
    max-height: 34px;
    height: auto;
    object-fit: contain;
}

.redaktion-nav {
    display: grid;
    gap: 8px;
}

.redaktion-nav a,
.redaktion-topbar a,
.redaktion-actions a,
.redaktion-button {
    border-radius: 6px;
    font-weight: 850;
}

.redaktion-nav a {
    padding: 11px 12px;
    color: var(--color-muted);
}

.redaktion-nav a:hover,
.redaktion-nav a:focus-visible {
    background: rgb(255 255 255 / 6%);
    color: var(--color-text);
}

.redaktion-main {
    min-width: 0;
    padding: clamp(20px, 4vw, 42px);
}

.redaktion-topbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 14px;
    color: var(--color-muted);
    font-size: 0.9rem;
}

.redaktion-topbar a,
.redaktion-alert a,
.redaktion-form__actions a {
    color: var(--color-accent-strong);
}

.redaktion-alert,
.redaktion-flash {
    margin-top: 18px;
    border: 1px solid rgb(245 184 0 / 34%);
    border-radius: 8px;
    background: rgb(245 184 0 / 10%);
    color: var(--color-text);
    padding: 12px 14px;
}

.redaktion-flash--success {
    border-color: rgb(34 197 94 / 42%);
    background: rgb(34 197 94 / 12%);
}

.redaktion-flash--danger,
.redaktion-card--warning {
    border-color: rgb(239 68 68 / 44%);
    background: rgb(239 68 68 / 10%);
}

.redaktion-header {
    margin-top: 28px;
    margin-bottom: 22px;
}

.redaktion-header h1 {
    margin: 0;
    font-size: clamp(2rem, 5vw, 3.8rem);
}

.redaktion-header p:last-child {
    max-width: 720px;
    color: var(--color-muted);
}

.redaktion-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
    margin-bottom: 18px;
}

.redaktion-grid--two {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.redaktion-card,
.redaktion-panel {
    border: 1px solid var(--color-surface-border);
    border-radius: 8px;
    background: var(--color-surface);
    box-shadow: var(--shadow-panel);
}

.redaktion-card {
    display: grid;
    gap: 8px;
    min-height: 118px;
    padding: 20px;
}

.redaktion-card strong {
    color: var(--color-text);
    font-size: 1.8rem;
}

.redaktion-card span,
.redaktion-empty {
    color: var(--color-muted);
}

.redaktion-panel {
    margin-bottom: 18px;
    padding: 20px;
}

.redaktion-panel__head {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
}

.redaktion-panel h2 {
    margin-top: 0;
}

.redaktion-summary-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 12px;
    margin-bottom: 18px;
}

.redaktion-summary-card {
    display: grid;
    gap: 5px;
    border: 1px solid var(--color-surface-border);
    border-radius: 8px;
    background: rgb(255 255 255 / 4%);
    padding: 14px;
}

.redaktion-summary-card strong {
    color: var(--color-accent-strong);
    font-size: 1.45rem;
}

.redaktion-summary-card span {
    color: var(--color-text);
    font-weight: 900;
}

.redaktion-summary-card small,
.redaktion-muted {
    color: var(--color-muted);
}

.redaktion-filterbar {
    display: grid;
    grid-template-columns: repeat(3, minmax(145px, 0.7fr)) minmax(220px, 1.1fr) auto;
    gap: 12px;
    align-items: end;
    border: 1px solid var(--color-surface-border);
    border-radius: 8px;
    background: rgb(255 255 255 / 4%);
    margin-bottom: 18px;
    padding: 14px;
}

.redaktion-filterbar--media {
    grid-template-columns: minmax(150px, 0.5fr) minmax(260px, 1fr) auto;
}

.redaktion-filterbar label {
    display: grid;
    gap: 5px;
    color: var(--color-muted);
    font-size: 0.82rem;
    font-weight: 850;
}

.redaktion-filterbar select,
.redaktion-filterbar input {
    min-height: 40px;
    border: 1px solid rgb(255 255 255 / 14%);
    border-radius: 7px;
    background: #0b1118;
    color: var(--color-text);
    padding: 8px 10px;
}

.redaktion-filterbar__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.redaktion-filterbar__actions button,
.redaktion-filterbar__actions a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 40px;
    border: 1px solid rgb(245 184 0 / 42%);
    border-radius: 7px;
    background: rgb(245 184 0 / 14%);
    color: var(--color-accent-strong);
    cursor: pointer;
    font-weight: 900;
    padding: 8px 12px;
    text-decoration: none;
}

.redaktion-actions,
.redaktion-form__actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
}

.redaktion-actions a,
.redaktion-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 0;
    background: var(--color-accent);
    color: #1f1600;
    cursor: pointer;
    padding: 11px 14px;
}

.redaktion-button--ghost {
    border: 1px solid var(--color-surface-border);
    background: rgb(255 255 255 / 4%);
    color: var(--color-text);
}

.redaktion-table {
    display: grid;
    gap: 8px;
}

.redaktion-table__head,
.redaktion-table__row {
    display: grid;
    grid-template-columns: minmax(210px, 1.35fr) minmax(92px, 0.5fr) minmax(105px, 0.55fr) minmax(150px, 0.75fr) minmax(96px, 0.5fr) minmax(130px, 0.65fr) minmax(125px, 0.6fr) minmax(210px, 1fr);
    gap: 12px;
    align-items: center;
}

.redaktion-table--media .redaktion-table__head,
.redaktion-table--media .redaktion-table__row {
    grid-template-columns: minmax(220px, 1.2fr) minmax(160px, 0.8fr) minmax(140px, 0.7fr) minmax(82px, 0.4fr) minmax(105px, 0.5fr) minmax(105px, 0.5fr) minmax(130px, 0.6fr) minmax(180px, 0.9fr);
}

.redaktion-table__head {
    color: var(--color-muted);
    font-size: 0.78rem;
    font-weight: 900;
    text-transform: uppercase;
}

.redaktion-table__row,
.redaktion-list__row {
    border: 1px solid rgb(255 255 255 / 8%);
    border-radius: 8px;
    background: rgb(255 255 255 / 4%);
    padding: 12px;
}

.redaktion-table__row span,
.redaktion-list__row span {
    min-width: 0;
    color: var(--color-muted);
    overflow-wrap: anywhere;
}

.redaktion-table__row small {
    display: block;
    margin-top: 5px;
    color: var(--color-muted);
    font-size: 0.76rem;
    line-height: 1.35;
}

.redaktion-status {
    display: inline-flex;
    border: 1px solid rgb(255 255 255 / 12%);
    border-radius: 999px;
    background: rgb(255 255 255 / 7%);
    color: var(--color-text);
    font-size: 0.76rem;
    font-weight: 900;
    line-height: 1.2;
    padding: 5px 8px;
}

.redaktion-status--complete {
    border-color: rgb(34 197 94 / 35%);
    background: rgb(34 197 94 / 12%);
    color: #bbf7d0;
}

.redaktion-status--seo_enabled {
    border-color: rgb(34 197 94 / 28%);
    background: rgb(34 197 94 / 10%);
    color: #bbf7d0;
}

.redaktion-status--missing_alt,
.redaktion-status--weak_alt,
.redaktion-status--seo_disabled {
    border-color: rgb(239 68 68 / 38%);
    background: rgb(239 68 68 / 12%);
    color: #fecaca;
}

.redaktion-status--needs_context {
    border-color: rgb(245 184 0 / 38%);
    background: rgb(245 184 0 / 12%);
    color: var(--color-accent-strong);
}

.redaktion-row-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.redaktion-row-actions__group {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.redaktion-row-actions__group--secondary {
    opacity: 0.86;
}

.redaktion-row-actions a,
.redaktion-row-actions button {
    border: 1px solid rgb(255 255 255 / 14%);
    border-radius: 6px;
    background: rgb(255 255 255 / 6%);
    color: var(--color-text);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    font-size: 0.78rem;
    font-weight: 850;
    padding: 7px 9px;
    text-decoration: none;
}

.redaktion-row-actions a:hover,
.redaktion-row-actions a:focus-visible,
.redaktion-row-actions button:hover,
.redaktion-row-actions button:focus-visible {
    border-color: rgb(245 184 0 / 56%);
    color: var(--color-accent-strong);
}

.redaktion-badge,
.redaktion-language-status,
.redaktion-quality-pill {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    border: 1px solid rgb(255 255 255 / 12%);
    border-radius: 999px;
    background: rgb(255 255 255 / 6%);
    color: var(--color-text);
    font-size: 0.76rem;
    font-weight: 900;
    padding: 4px 8px;
}

.redaktion-language-statuses {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
}

.redaktion-language-status--published {
    border-color: rgb(34 197 94 / 38%);
    color: #86efac;
}

.redaktion-language-status--missing,
.redaktion-quality-pill.is-blocking {
    border-color: rgb(239 68 68 / 42%);
    color: #fca5a5;
}

.redaktion-language-status--needs_update {
    border-color: rgb(245 184 0 / 42%);
    color: var(--color-accent-strong);
}

.redaktion-language-status--review,
.redaktion-language-status--machine_translated {
    border-color: rgb(96 165 250 / 42%);
    color: #93c5fd;
}

.redaktion-language-status--draft {
    border-color: rgb(255 255 255 / 18%);
    color: var(--color-muted);
}

.redaktion-quality-pill {
    gap: 5px;
}

.redaktion-quality-pill small {
    color: inherit;
    font-size: 0.68rem;
    opacity: 0.84;
}

.redaktion-list {
    display: grid;
    gap: 8px;
}

.lumiri-conversation-list {
    display: grid;
    gap: 14px;
}

.lumiri-conversation {
    display: grid;
    gap: 12px;
    border: 1px solid rgb(255 255 255 / 10%);
    border-radius: 8px;
    background: rgb(255 255 255 / 4%);
    padding: 14px;
}

.lumiri-conversation__head,
.lumiri-message__meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.lumiri-conversation__head h3 {
    margin: 0;
}

.lumiri-conversation__messages {
    display: grid;
    gap: 10px;
}

.lumiri-message {
    border-left: 3px solid rgb(255 255 255 / 14%);
    background: rgb(0 0 0 / 16%);
    padding: 10px 12px;
}

.lumiri-message--lumiri {
    border-left-color: var(--color-accent);
}

.lumiri-message__meta {
    color: var(--color-muted);
    font-size: 0.82rem;
}

.lumiri-message p {
    margin-bottom: 0;
}

.redaktion-list__row {
    display: grid;
    grid-template-columns: minmax(180px, 1.1fr) minmax(140px, 0.9fr) minmax(160px, 1fr);
    gap: 12px;
}

.redaktion-form,
.redaktion-form__main,
.redaktion-form__side {
    display: grid;
    gap: 14px;
}

.redaktion-form-toolbar {
    position: sticky;
    top: 12px;
    z-index: 6;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    border: 1px solid rgb(245 184 0 / 28%);
    border-radius: 8px;
    background: rgb(11 17 24 / 94%);
    box-shadow: 0 16px 36px rgb(0 0 0 / 30%);
    padding: 12px 14px;
    backdrop-filter: blur(14px);
}

.redaktion-form-toolbar strong {
    display: block;
    color: var(--color-text);
}

.redaktion-form-toolbar span {
    display: block;
    color: var(--color-muted);
    font-size: 0.88rem;
    line-height: 1.45;
}

.redaktion-form-toolbar__actions {
    display: flex;
    align-items: center;
    flex: 0 0 auto;
    gap: 10px;
}

.redaktion-form__grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
    gap: 18px;
    align-items: start;
}

.redaktion-form label {
    display: block;
    margin-bottom: 6px;
    color: var(--color-muted);
    font-weight: 800;
}

.redaktion-form input,
.redaktion-form select,
.redaktion-form textarea {
    width: 100%;
    border: 1px solid var(--color-surface-border);
    border-radius: 6px;
    background: var(--color-bg);
    color: var(--color-text);
    padding: 12px 14px;
}

.redaktion-form input[type="checkbox"],
.redaktion-form input[type="radio"] {
    width: auto;
    min-width: 16px;
    margin-right: 8px;
}

.redaktion-form fieldset {
    display: grid;
    gap: 8px;
    border: 1px solid rgb(255 255 255 / 10%);
    border-radius: 6px;
    padding: 12px;
}

.redaktion-form fieldset legend {
    color: var(--color-muted);
    font-size: 0.78rem;
    font-weight: 900;
    text-transform: uppercase;
}

.redaktion-form fieldset .form-check,
.redaktion-form fieldset label {
    display: flex;
    align-items: center;
    margin: 0;
}

.redaktion-form-counter-field {
    display: grid;
    gap: 5px;
}

.redaktion-form-counter {
    justify-self: end;
    color: var(--color-muted);
    font-size: 0.78rem;
    font-weight: 800;
}

.redaktion-form-counter.is-warning {
    color: #f59e0b;
}

.redaktion-form-counter.is-danger {
    color: #fecaca;
}

.redaktion-form-counter-field.is-warning input,
.redaktion-form-counter-field.is-warning textarea {
    border-color: rgb(245 158 11 / 72%);
}

.redaktion-form-counter-field.is-danger input,
.redaktion-form-counter-field.is-danger textarea {
    border-color: var(--color-danger);
}

.review-platform-picker {
    display: grid;
    gap: 12px;
}

.review-platform-picker__head {
    display: grid;
    gap: 4px;
}

.review-platform-picker__head > label {
    margin-bottom: 0;
}

.review-platform-picker__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.review-platform-group {
    display: grid;
    align-content: start;
    gap: 8px;
    min-height: 110px;
    border: 1px solid rgb(255 255 255 / 12%);
    border-radius: 6px;
    background: rgb(255 255 255 / 3%);
    padding: 12px;
}

.review-platform-group[hidden] {
    display: none;
}

[data-review-platforms-subject-value][hidden] {
    display: none;
}

.review-platform-group legend {
    color: var(--color-text);
    font-size: 0.75rem;
    font-weight: 900;
    text-transform: uppercase;
}

.review-platform-choice {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 0;
    color: var(--color-text);
    font-size: 0.9rem;
    font-weight: 650;
}

.review-platform-choice input[type="checkbox"] {
    flex: 0 0 auto;
    margin: 0;
}

.redaktion-form textarea {
    min-height: 140px;
    resize: vertical;
}

.redaktion-editor__form {
    gap: 18px;
}

.redaktion-editor__title {
    display: grid;
    gap: 10px;
}

.redaktion-editor__title input {
    font-size: clamp(1.45rem, 3vw, 2.25rem);
    font-weight: 900;
}

.redaktion-editor__grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(300px, 380px);
    gap: 18px;
    align-items: start;
}

.redaktion-editor__main,
.redaktion-editor__side,
.redaktion-editor-box {
    display: grid;
    gap: 14px;
}

.redaktion-editor-box {
    border: 1px solid rgb(255 255 255 / 9%);
    border-radius: 8px;
    background: rgb(255 255 255 / 4%);
    padding: 14px;
}

.redaktion-editor__sidebar-section {
    scroll-margin-top: 90px;
}

.redaktion-editor-actions {
    border-color: rgb(245 158 11 / 32%);
    background: rgb(245 158 11 / 6%);
}

.redaktion-editor-box h2 {
    margin: 0;
    font-size: 1rem;
}

.redaktion-editor-hints {
    display: grid;
    gap: 6px;
    margin: 0;
    border: 1px solid rgb(245 184 0 / 24%);
    border-radius: 8px;
    background: rgb(245 184 0 / 7%);
    color: var(--color-muted);
    padding: 12px 12px 12px 28px;
}

.redaktion-translation-studio {
    display: grid;
    gap: 18px;
}

.redaktion-translation-reference {
    border-bottom: 1px solid rgb(255 255 255 / 8%);
    padding-bottom: 18px;
}

.redaktion-reference-list {
    display: grid;
    gap: 10px;
    margin: 0;
}

.redaktion-reference-list div {
    display: grid;
    gap: 4px;
}

.redaktion-reference-list dt {
    color: var(--color-muted);
    font-size: 0.78rem;
    font-weight: 900;
    text-transform: uppercase;
}

.redaktion-reference-list dd {
    margin: 0;
}

.redaktion-reference-body {
    max-height: 340px;
    overflow: auto;
    border: 1px solid rgb(255 255 255 / 8%);
    border-radius: 8px;
    background: rgb(0 0 0 / 18%);
    color: var(--color-muted);
    padding: 14px;
}

.redaktion-media-status-card {
    display: grid;
    grid-template-columns: 86px minmax(0, 1fr);
    gap: 12px;
    align-items: start;
    border: 1px solid rgb(255 255 255 / 9%);
    border-radius: 8px;
    background: rgb(255 255 255 / 4%);
    padding: 10px;
}

.redaktion-media-status-card img {
    width: 86px;
    aspect-ratio: 4 / 3;
    border-radius: 6px;
    object-fit: cover;
}

.redaktion-media-status-card p,
.redaktion-media-status-card ul {
    margin: 8px 0 0;
    color: var(--color-muted);
}

.redaktion-media-status-card ul {
    padding-left: 18px;
}

.redaktion-featured-media-upload__inline {
    display: grid;
    gap: 8px;
    border-top: 1px solid rgb(255 255 255 / 8%);
    padding-top: 12px;
}

.redaktion-featured-media-upload__inline label {
    color: var(--color-muted);
    font-size: 0.82rem;
    font-weight: 900;
}

.redaktion-featured-media-upload__fallback {
    display: grid;
    gap: 8px;
}

.redaktion-featured-media-upload__actions {
    display: grid;
    gap: 8px;
    border-top: 1px solid rgb(255 255 255 / 8%);
    padding-top: 12px;
}

.redaktion-featured-media-upload__actions .redaktion-button {
    justify-self: start;
}

.redaktion-featured-media-upload__library {
    display: grid;
    gap: 12px;
    border: 1px solid rgb(255 255 255 / 10%);
    border-radius: 8px;
    background: rgb(255 255 255 / 4%);
    margin-top: 12px;
    padding: 12px;
}

.redaktion-featured-media-upload__library[hidden] {
    display: none;
}

.redaktion-featured-media-upload__library-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.redaktion-featured-media-upload__library-header h3 {
    margin: 0;
    color: var(--color-text);
    font-size: 0.95rem;
}

.redaktion-featured-media-upload__close {
    border: 1px solid var(--color-surface-border);
    border-radius: 6px;
    background: rgb(255 255 255 / 5%);
    color: var(--color-text);
    cursor: pointer;
    font-weight: 850;
    padding: 7px 10px;
}

.redaktion-featured-media-upload__search {
    width: 100%;
    min-height: 40px;
    border: 1px solid var(--color-surface-border);
    border-radius: 7px;
    background: #0b1118;
    color: var(--color-text);
    padding: 9px 11px;
}

.redaktion-featured-media-upload__library-status {
    min-height: 1.2rem;
    margin: 0;
}

.redaktion-featured-media-upload__grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(132px, 1fr));
    gap: 10px;
    max-height: 360px;
    overflow: auto;
    padding-right: 3px;
}

.redaktion-featured-media-upload__item {
    display: grid;
    grid-template-rows: 84px auto auto;
    gap: 7px;
    min-width: 0;
    border: 1px solid rgb(255 255 255 / 12%);
    border-radius: 8px;
    background: rgb(255 255 255 / 4%);
    color: var(--color-text);
    cursor: pointer;
    padding: 8px;
    text-align: left;
}

.redaktion-featured-media-upload__item:hover,
.redaktion-featured-media-upload__item:focus-visible,
.redaktion-featured-media-upload__item.is-selected {
    border-color: rgb(245 184 0 / 60%);
    background: rgb(245 184 0 / 11%);
    outline: none;
}

.redaktion-featured-media-upload__item img {
    width: 100%;
    height: 84px;
    border-radius: 6px;
    background: var(--color-bg);
    object-fit: cover;
}

.redaktion-featured-media-upload__item-title {
    overflow: hidden;
    color: var(--color-text);
    font-size: 0.78rem;
    font-weight: 850;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.redaktion-featured-media-upload__button {
    justify-self: start;
}

.redaktion-featured-media-upload__status {
    min-height: 1.25rem;
}

.redaktion-featured-media-upload__status[data-state="success"] {
    color: #86efac;
}

.redaktion-featured-media-upload__status[data-state="error"] {
    color: #fca5a5;
}

.redaktion-save-row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
}

.redaktion-autosave-status {
    border: 1px solid var(--color-surface-border);
    border-radius: 999px;
    background: rgb(255 255 255 / 4%);
    color: var(--color-muted);
    font-size: 0.78rem;
    font-weight: 900;
    padding: 7px 10px;
}

.redaktion-autosave-status[data-state="saving"],
.redaktion-autosave-status[data-state="pending"] {
    border-color: rgb(245 184 0 / 42%);
    color: var(--color-accent-strong);
}

.redaktion-autosave-status[data-state="saved"] {
    border-color: rgb(34 197 94 / 32%);
    color: #86efac;
}

.redaktion-autosave-status[data-state="error"] {
    border-color: rgb(239 68 68 / 42%);
    color: #fca5a5;
}

.redaktion-quality__score {
    margin: 0;
    color: var(--color-muted);
    font-size: 0.88rem;
    font-weight: 800;
}

.redaktion-quality__list {
    display: grid;
    gap: 8px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.redaktion-quality__list li {
    display: grid;
    grid-template-columns: 30px minmax(0, 1fr);
    gap: 10px;
    align-items: start;
    border: 1px solid var(--color-surface-border);
    border-radius: 8px;
    background: rgb(255 255 255 / 3%);
    padding: 10px;
}

.redaktion-quality__list li > span {
    display: inline-grid;
    min-width: 30px;
    min-height: 30px;
    place-items: center;
    border-radius: 50%;
    font-size: 0.75rem;
    font-weight: 900;
}

.redaktion-quality__list li.is-passed > span {
    background: rgb(34 197 94 / 18%);
    color: #86efac;
}

.redaktion-quality__list li.is-missing > span {
    background: rgb(245 184 0 / 16%);
    color: var(--color-accent-strong);
}

.redaktion-quality__list li.is-missing.is-required {
    border-color: rgb(239 68 68 / 48%);
    background: rgb(239 68 68 / 7%);
}

.redaktion-quality__list li.is-missing.is-required > span {
    background: rgb(239 68 68 / 18%);
    color: #fca5a5;
}

.redaktion-quality__list strong,
.redaktion-quality__list small {
    display: block;
}

.redaktion-quality__list small {
    margin-top: 3px;
    color: var(--color-muted);
    line-height: 1.35;
}

.redaktion-muted {
    margin: 0;
    color: var(--color-muted);
}

.redaktion-revisions__list {
    display: grid;
    gap: 8px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.redaktion-revisions__list li {
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: 8px;
    border: 1px solid var(--color-surface-border);
    border-radius: 8px;
    background: rgb(255 255 255 / 3%);
    padding: 10px;
}

.redaktion-revisions__list li > div {
    display: grid;
    gap: 3px;
}

.redaktion-revisions__actions {
    display: flex;
    align-items: center;
    gap: 0.45rem;
}

.redaktion-revisions__actions a {
    color: var(--color-accent-strong);
    font-size: 0.86rem;
    text-decoration: none;
}

.redaktion-revisions__list form {
    margin: 0;
}

.redaktion-revisions__list button {
    border: 1px solid rgba(245, 184, 0, 0.45);
    border-radius: 6px;
    background: rgba(245, 184, 0, 0.1);
    color: var(--color-accent-strong);
    cursor: pointer;
    font: inherit;
    padding: 0.35rem 0.55rem;
}

.redaktion-revision-compare {
    display: grid;
    gap: 1rem;
}

.redaktion-revision-compare__toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.redaktion-revision-compare__toolbar form {
    margin: 0;
}

.redaktion-revision-compare__notice {
    margin: 0;
    border: 1px solid rgb(34 197 94 / 32%);
    border-radius: 8px;
    background: rgb(34 197 94 / 10%);
    color: #86efac;
    padding: 0.8rem;
}

.redaktion-revision-compare__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1rem;
}

.redaktion-revision-compare article {
    display: grid;
    gap: 0.8rem;
    align-content: start;
}

.redaktion-revision-compare article > section {
    border: 1px solid var(--color-surface-border);
    border-radius: 8px;
    background: rgb(255 255 255 / 3%);
    padding: 0.8rem;
}

.redaktion-revision-compare article > section.is-changed {
    border-color: rgb(245 184 0 / 50%);
    background: rgb(245 184 0 / 7%);
}

.redaktion-revision-compare article > section.is-unchanged {
    opacity: 0.74;
}

.redaktion-revision-compare h2,
.redaktion-revision-compare h3 {
    margin: 0;
}

.redaktion-revision-compare h3 {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.redaktion-revision-compare h3 span {
    border: 1px solid var(--color-surface-border);
    border-radius: 999px;
    color: var(--color-muted);
    font-size: 0.72rem;
    padding: 0.2rem 0.45rem;
}

.redaktion-revision-compare .is-changed h3 span {
    border-color: rgb(245 184 0 / 48%);
    color: var(--color-accent-strong);
}

.redaktion-revision-compare pre {
    max-height: 360px;
    margin: 0.5rem 0 0;
    overflow: auto;
    white-space: pre-wrap;
    word-break: break-word;
    color: var(--color-muted);
    font: 0.9rem/1.5 ui-monospace, SFMono-Regular, Consolas, Liberation Mono, monospace;
}

.redaktion-revision-line-diff {
    border: 1px solid var(--color-surface-border);
    border-radius: 8px;
    background: rgb(255 255 255 / 3%);
    padding: 0.9rem;
}

.redaktion-revision-line-diff h2 {
    margin: 0 0 0.75rem;
}

.redaktion-revision-line-diff ol {
    display: grid;
    gap: 3px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.redaktion-revision-line-diff li {
    display: grid;
    grid-template-columns: 2rem minmax(0, 1fr);
    gap: 0.55rem;
    border-radius: 6px;
    padding: 0.35rem 0.45rem;
}

.redaktion-revision-line-diff li.is-added {
    background: rgb(34 197 94 / 12%);
}

.redaktion-revision-line-diff li.is-removed {
    background: rgb(239 68 68 / 12%);
}

.redaktion-revision-line-diff li.is-context {
    color: var(--color-muted);
}

.redaktion-revision-line-diff span {
    color: var(--color-muted);
    font-weight: 900;
    text-align: center;
}

.redaktion-revision-line-diff li.is-added span {
    color: #86efac;
}

.redaktion-revision-line-diff li.is-removed span {
    color: #fca5a5;
}

.redaktion-revision-line-diff code {
    white-space: pre-wrap;
    word-break: break-word;
}

@media (max-width: 900px) {
    .redaktion-revisions__list li,
    .redaktion-revision-compare__grid,
    .redaktion-revision-compare__toolbar {
        grid-template-columns: 1fr;
    }

    .redaktion-revision-compare__toolbar {
        align-items: stretch;
    }
}

.redaktion-revisions__list strong {
    color: var(--color-text);
}

.redaktion-revisions__list span,
.redaktion-revisions__list small {
    color: var(--color-muted);
    font-size: 0.82rem;
}

.redaktion-editor .wysiwyg-editor {
    min-height: 560px;
}

.redaktion-editor .wysiwyg-editor__content {
    min-height: 520px;
}

.redaktion-media-edit {
    display: grid;
    grid-template-columns: minmax(280px, 0.8fr) minmax(0, 1fr);
    gap: 18px;
    align-items: start;
}

.redaktion-media-edit__preview {
    margin: 0;
}

.redaktion-media-edit__preview img {
    width: 100%;
    border: 1px solid var(--color-surface-border);
    border-radius: 8px;
    aspect-ratio: 16 / 10;
    background: var(--color-bg);
    object-fit: cover;
}

.redaktion-media-edit__preview figcaption {
    margin-top: 8px;
    color: var(--color-muted);
}

.page-builder {
    display: grid;
    gap: 18px;
}

.page-builder .content-panel__head,
.page-builder-block__header,
.page-builder-block__actions,
.page-builder-toolbar,
.page-builder-add {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
}

.page-builder .content-panel__head,
.page-builder-block__header {
    justify-content: space-between;
}

.page-builder-list {
    display: grid;
    gap: 18px;
}

.page-builder-block {
    display: grid;
    gap: 16px;
}

.page-builder-block__handle {
    display: inline-flex;
    align-items: center;
    min-height: 32px;
    padding: 6px 10px;
    border: 1px solid var(--color-surface-border);
    border-radius: 6px;
    color: var(--color-muted);
    cursor: grab;
    font-size: 0.82rem;
    font-weight: 800;
}

.page-builder-block__form,
.page-builder-fields {
    display: grid;
    gap: 12px;
}

.page-builder-block__preview {
    display: grid;
    gap: 10px;
    min-width: 0;
    border: 1px solid rgb(255 255 255 / 10%);
    border-radius: 8px;
    background: rgb(255 255 255 / 3%);
    padding: 12px;
}

.page-builder-block__preview-head {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 12px;
    align-items: baseline;
    justify-content: space-between;
}

.page-builder-preview-frame {
    min-width: 0;
    overflow: hidden;
    border: 1px solid var(--color-surface-border);
    border-radius: 8px;
    background: var(--color-bg);
    color: var(--color-text);
    padding: 16px;
}

.page-builder-preview-frame .page-block {
    margin-block: 0;
}

.page-builder-preview-frame .page-block--hero,
.page-builder-preview-frame .page-block--cta {
    padding: clamp(22px, 4vw, 40px);
}

.page-builder-preview-frame .page-block--hero h1 {
    font-size: clamp(2rem, 4vw, 3.2rem);
}

.page-builder-preview-frame .page-block--hero-media {
    grid-template-columns: minmax(0, 1fr) minmax(220px, 300px);
}

.page-builder-preview-frame .page-card-grid,
.page-builder-preview-frame .content-grid {
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.page-builder-fields label {
    display: grid;
    gap: 6px;
    color: var(--color-muted);
    font-weight: 800;
}

.page-builder-fields input,
.page-builder-fields select,
.page-builder-fields textarea,
.page-builder-add select {
    width: 100%;
    border: 1px solid var(--color-surface-border);
    border-radius: 6px;
    background: var(--color-bg);
    color: var(--color-text);
    padding: 10px 12px;
}

.page-builder-fields textarea {
    min-height: 120px;
    resize: vertical;
}

.page-block {
    margin-block: 22px;
}

.page-block--hero,
.page-block--cta {
    overflow: hidden;
    border: 1px solid rgb(255 255 255 / 12%);
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgb(245 184 0 / 16%), rgb(255 255 255 / 0) 44%),
        linear-gradient(180deg, rgb(17 24 32 / 96%), rgb(8 13 19 / 96%));
    padding: clamp(32px, 6vw, 76px);
}

.page-block--hero-media {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 0.8fr);
    gap: 26px;
    align-items: center;
}

.page-block--hero-media img {
    order: 2;
    border-radius: 8px;
    aspect-ratio: 16 / 9;
    object-fit: cover;
}

.page-rating-guide .page-block--hero-media {
    position: relative;
    isolation: isolate;
    align-items: end;
    grid-template-columns: minmax(0, 1fr);
    aspect-ratio: 2172 / 724;
    min-height: clamp(360px, 30vw, 440px);
    padding: clamp(18px, 3vw, 34px);
    background:
        linear-gradient(90deg, rgb(5 8 13 / 82%) 0%, rgb(5 8 13 / 46%) 52%, rgb(5 8 13 / 18%) 100%),
        linear-gradient(180deg, rgb(5 8 13 / 10%) 0%, rgb(5 8 13 / 88%) 100%);
    background-color: #05080d;
}

.page-rating-guide .page-block--hero-media img {
    position: absolute;
    inset: 0;
    z-index: -1;
    order: 0;
    width: 100%;
    height: 100%;
    border-radius: inherit;
    aspect-ratio: auto;
    object-fit: contain;
    object-position: center top;
}

.page-rating-guide .page-block--hero-media > div {
    display: grid;
    gap: 14px;
    max-width: 690px;
    border: 1px solid rgb(255 255 255 / 14%);
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgb(245 184 0 / 13%), transparent 44%),
        rgb(5 8 13 / 76%);
    padding: clamp(20px, 3vw, 34px);
    box-shadow: 0 22px 70px rgb(0 0 0 / 42%), 0 1px 0 rgb(255 255 255 / 5%) inset;
    backdrop-filter: blur(8px);
}

.page-rating-guide .page-block--hero .eyebrow {
    margin: 0;
}

.page-block--hero h1 {
    max-width: 780px;
    margin: 0;
    font-size: clamp(2.4rem, 6vw, 5.4rem);
}

.page-rating-guide .page-block--hero h1 {
    max-width: 620px;
    font-size: clamp(2.25rem, 5vw, 4.65rem);
    line-height: 0.96;
    text-wrap: balance;
}

.page-rating-guide .page-block--hero > div > p:not(.eyebrow) {
    max-width: 650px;
    margin: 0;
    color: rgb(245 247 250 / 88%);
    font-size: clamp(0.98rem, 1.2vw, 1.08rem);
    line-height: 1.65;
}

.page-rating-guide .page-block--hero .button,
.page-rating-guide .page-block--cta .button {
    justify-self: start;
    width: auto;
}

.page-block--rich-text {
    max-width: 860px;
}

.page-block--media img {
    width: 100%;
    border-radius: 8px;
    border: 1px solid var(--color-surface-border);
}

.page-block--media figcaption {
    margin-top: 8px;
    color: var(--color-muted);
}

.page-block--two-columns {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 22px;
}

.page-card-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
}

.page-rating-guide .content-page {
    display: grid;
    gap: clamp(22px, 4vw, 42px);
}

.page-rating-guide .page-block {
    margin-block: 0;
}

.page-rating-guide .page-block--rich-text {
    width: min(100%, 900px);
    max-width: none;
    margin-inline: auto;
    border: 1px solid rgb(255 255 255 / 10%);
    border-left: 3px solid rgb(245 184 0 / 78%);
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgb(245 184 0 / 8%), transparent 34%),
        rgb(5 8 13 / 54%);
    padding: clamp(20px, 3vw, 34px);
    box-shadow: 0 18px 44px rgb(0 0 0 / 18%);
}

.page-rating-guide .page-block--rich-text h2 {
    margin-top: 0;
    margin-bottom: 12px;
    color: var(--color-text);
    font-size: clamp(1.45rem, 2.2vw, 2rem);
    line-height: 1.08;
}

.page-rating-guide .page-block--rich-text h2:not(:first-child) {
    margin-top: 30px;
}

.page-rating-guide .page-block--rich-text p {
    max-width: 75ch;
    color: rgb(245 247 250 / 82%);
    font-size: 1rem;
    line-height: 1.78;
}

.page-rating-guide .page-block--card-grid {
    display: grid;
    gap: 18px;
}

.page-rating-guide .page-block--card-grid > h2 {
    margin: 0;
    font-size: clamp(1.6rem, 3vw, 2.35rem);
    line-height: 1.08;
}

.page-rating-guide .page-card-grid {
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: clamp(14px, 2vw, 20px);
}

.page-rating-guide .page-card-grid .content-card {
    position: relative;
    min-height: 100%;
    overflow: hidden;
    border-color: rgb(255 255 255 / 13%);
    border-radius: 8px;
    background:
        linear-gradient(180deg, rgb(255 255 255 / 5%), transparent 34%),
        linear-gradient(180deg, rgb(17 24 32 / 96%), rgb(7 11 17 / 96%));
    box-shadow: 0 18px 42px rgb(0 0 0 / 22%), 0 1px 0 rgb(255 255 255 / 5%) inset;
}

.page-rating-guide .page-card-grid .content-card::after {
    position: absolute;
    inset: auto 0 0;
    height: 3px;
    background: var(--rating-card-accent, var(--color-accent));
    content: "";
    opacity: 0.9;
}

.page-rating-guide .page-card-grid .content-card:hover,
.page-rating-guide .page-card-grid .content-card:focus-within {
    border-color: color-mix(in srgb, var(--rating-card-accent, var(--color-accent)) 64%, white 8%);
    transform: translateY(-2px);
}

.page-card__media,
.page-rating-guide .page-card-grid .content-card:not(.page-card--with-media)::before {
    display: block;
    aspect-ratio: 16 / 7.3;
    min-height: 126px;
    overflow: hidden;
    border-bottom: 1px solid rgb(255 255 255 / 10%);
    background-color: var(--color-bg-soft);
    background-repeat: no-repeat;
    background-size: 640% auto;
    background-position: var(--rating-card-position, 50% 50%);
}

.page-rating-guide .page-card__media,
.page-rating-guide .page-card-grid .content-card:not(.page-card--with-media)::before {
    background-image: url("/images/sections/betygsskala.webp");
    background-size: 1080% auto;
}

.page-rating-guide .page-card-grid .content-card:not(.page-card--with-media)::before {
    content: "";
}

.page-card__media img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: var(--rating-card-position, center);
}

.page-card__body {
    display: grid;
    align-content: start;
    gap: 10px;
    min-width: 0;
    padding: 18px;
}

.page-card__label {
    justify-self: start;
    border: 1px solid color-mix(in srgb, var(--rating-card-accent, var(--color-accent)) 54%, white 10%);
    border-radius: 999px;
    background: color-mix(in srgb, var(--rating-card-accent, var(--color-accent)) 16%, transparent);
    color: color-mix(in srgb, var(--rating-card-accent, var(--color-accent)) 78%, white 20%);
    padding: 6px 9px;
}

.page-card__body h3 {
    margin: 0;
    color: var(--color-text);
    font-size: clamp(1.15rem, 1.6vw, 1.45rem);
    line-height: 1.08;
}

.page-rating-guide .page-card__body h3 {
    font-size: clamp(1rem, 1.15vw, 1.24rem);
    overflow-wrap: anywhere;
}

.page-card__body p {
    margin: 0;
    color: rgb(245 247 250 / 76%);
    line-height: 1.62;
}

.page-card--rating-step-1,
.page-card--rating-avoid,
.page-rating-guide .page-card-grid .content-card:nth-child(1) {
    --rating-card-accent: #ef4444;
    --rating-card-position: 7% 50%;
}

.page-card--rating-step-2,
.page-rating-guide .page-card-grid .content-card:nth-child(2) {
    --rating-card-accent: #f97316;
    --rating-card-position: 15% 50%;
}

.page-card--rating-step-3,
.page-card--rating-weak,
.page-rating-guide .page-card-grid .content-card:nth-child(3) {
    --rating-card-accent: #f59e0b;
    --rating-card-position: 24% 50%;
}

.page-card--rating-step-4,
.page-rating-guide .page-card-grid .content-card:nth-child(4) {
    --rating-card-accent: #facc15;
    --rating-card-position: 33% 50%;
}

.page-card--rating-step-5,
.page-card--rating-okay,
.page-rating-guide .page-card-grid .content-card:nth-child(5) {
    --rating-card-accent: #84cc16;
    --rating-card-position: 42% 50%;
}

.page-card--rating-step-6,
.page-rating-guide .page-card-grid .content-card:nth-child(6) {
    --rating-card-accent: #38bdf8;
    --rating-card-position: 51% 50%;
}

.page-card--rating-step-7,
.page-card--rating-good,
.page-rating-guide .page-card-grid .content-card:nth-child(7) {
    --rating-card-accent: #a78bfa;
    --rating-card-position: 60% 50%;
}

.page-card--rating-step-8,
.page-rating-guide .page-card-grid .content-card:nth-child(8) {
    --rating-card-accent: #f472b6;
    --rating-card-position: 69% 50%;
}

.page-card--rating-step-9,
.page-card--rating-fantastic,
.page-rating-guide .page-card-grid .content-card:nth-child(9) {
    --rating-card-accent: #c084fc;
    --rating-card-position: 78% 50%;
}

.page-card--rating-step-10,
.page-card--rating-masterpiece,
.page-rating-guide .page-card-grid .content-card:nth-child(10) {
    --rating-card-accent: #fbbf24;
    --rating-card-position: 88% 50%;
}

.page-rating-guide .page-card--rating-step-10 .page-card__media img,
.page-rating-guide .page-card--rating-masterpiece .page-card__media img {
    object-position: 91% 50%;
}

.page-rating-guide .page-card__media img {
    opacity: 0;
}

.page-rating-guide .page-block--cta {
    display: grid;
    gap: 16px;
    border-color: rgb(245 184 0 / 26%);
    background:
        linear-gradient(115deg, rgb(245 184 0 / 16%) 0%, transparent 42%),
        linear-gradient(180deg, rgb(17 24 32 / 96%), rgb(7 11 17 / 96%));
    box-shadow: 0 22px 58px rgb(0 0 0 / 24%);
}

.page-rating-guide .page-block--cta h2 {
    margin: 0;
    font-size: clamp(1.45rem, 2.2vw, 2rem);
}

.page-rating-guide .page-block--cta p {
    max-width: 62ch;
    margin: 0;
    color: rgb(245 247 250 / 78%);
    line-height: 1.7;
}

.content-page {
    padding-bottom: 42px;
}

.legal-page {
    width: min(100% - 40px, 1180px);
}

.legal-hero {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 28px;
    margin-top: 24px;
    overflow: hidden;
    border: 1px solid rgb(245 184 0 / 22%);
    border-radius: 8px;
    background:
        linear-gradient(116deg, rgb(245 184 0 / 14%) 0%, transparent 42%),
        linear-gradient(250deg, rgb(39 177 169 / 11%) 0%, transparent 46%),
        linear-gradient(180deg, rgb(17 24 32 / 96%), rgb(8 13 19 / 96%));
    padding: 38px;
    box-shadow: var(--shadow-panel);
}

.legal-hero--privacy {
    background:
        linear-gradient(90deg, rgb(5 8 13 / 95%) 0%, rgb(5 8 13 / 76%) 46%, rgb(5 8 13 / 42%) 100%),
        linear-gradient(180deg, rgb(5 8 13 / 18%) 0%, rgb(5 8 13 / 78%) 100%),
        var(--listing-hero-image, linear-gradient(135deg, rgb(17 24 32), rgb(8 13 19))),
        linear-gradient(118deg, rgb(245 184 0 / 13%) 0%, rgb(96 165 250 / 11%) 42%, transparent 72%),
        linear-gradient(180deg, rgb(17 24 32 / 96%), rgb(7 11 17 / 96%));
}

.legal-hero--terms {
    background:
        linear-gradient(90deg, rgb(5 8 13 / 95%) 0%, rgb(5 8 13 / 76%) 46%, rgb(5 8 13 / 42%) 100%),
        linear-gradient(180deg, rgb(5 8 13 / 18%) 0%, rgb(5 8 13 / 78%) 100%),
        var(--listing-hero-image, linear-gradient(135deg, rgb(17 24 32), rgb(8 13 19))),
        linear-gradient(118deg, rgb(245 184 0 / 14%) 0%, rgb(59 130 246 / 13%) 44%, transparent 72%),
        linear-gradient(180deg, rgb(17 24 32 / 96%), rgb(7 11 17 / 96%));
}

.legal-hero--disclaimer {
    background:
        linear-gradient(90deg, rgb(5 8 13 / 95%) 0%, rgb(5 8 13 / 76%) 46%, rgb(5 8 13 / 42%) 100%),
        linear-gradient(180deg, rgb(5 8 13 / 18%) 0%, rgb(5 8 13 / 78%) 100%),
        var(--listing-hero-image, linear-gradient(135deg, rgb(17 24 32), rgb(8 13 19))),
        linear-gradient(118deg, rgb(245 184 0 / 14%) 0%, rgb(239 68 68 / 9%) 42%, transparent 72%),
        linear-gradient(180deg, rgb(17 24 32 / 96%), rgb(7 11 17 / 96%));
}

.legal-hero--copyright {
    background:
        linear-gradient(90deg, rgb(5 8 13 / 95%) 0%, rgb(5 8 13 / 76%) 46%, rgb(5 8 13 / 42%) 100%),
        linear-gradient(180deg, rgb(5 8 13 / 18%) 0%, rgb(5 8 13 / 78%) 100%),
        var(--listing-hero-image, linear-gradient(135deg, rgb(17 24 32), rgb(8 13 19))),
        linear-gradient(118deg, rgb(59 130 246 / 13%) 0%, rgb(245 184 0 / 12%) 44%, transparent 72%),
        linear-gradient(180deg, rgb(17 24 32 / 96%), rgb(7 11 17 / 96%));
}

.legal-hero--with-image {
    background-color: var(--color-bg-soft);
    background-position: center, center, right center, center, center;
    background-repeat: no-repeat;
    background-size: cover, cover, contain, cover, cover;
}

.legal-hero__content {
    max-width: 780px;
}

.legal-hero h1 {
    max-width: 760px;
    margin: 0;
    color: var(--color-text);
    font-size: 3.65rem;
    line-height: 1.02;
    overflow-wrap: anywhere;
}

.legal-hero__lead {
    max-width: 740px;
    margin: 18px 0 0;
    color: rgb(245 247 250 / 86%);
    font-size: 1.02rem;
    line-height: 1.72;
}

.legal-hero__facts {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 22px;
}

.legal-hero__facts span {
    border: 1px solid rgb(255 255 255 / 12%);
    border-radius: 999px;
    background: rgb(255 255 255 / 5%);
    padding: 7px 10px;
    color: var(--color-muted);
    font-size: 0.78rem;
    font-weight: 800;
    text-transform: uppercase;
}

.legal-hero__button {
    flex: 0 0 auto;
}

.legal-layout {
    display: grid;
    grid-template-columns: minmax(190px, 250px) minmax(0, 780px);
    gap: 30px;
    align-items: start;
    margin-block: 30px 58px;
}

.legal-nav {
    position: sticky;
    top: 110px;
    border: 1px solid rgb(255 255 255 / 10%);
    border-radius: 8px;
    background: rgb(8 13 19 / 78%);
    padding: 18px;
}

.legal-nav p {
    margin: 0 0 12px;
    color: var(--color-accent);
    font-size: 0.78rem;
    font-weight: 900;
    letter-spacing: 0;
    text-transform: uppercase;
}

.legal-nav nav {
    display: grid;
    gap: 8px;
}

.legal-nav a {
    border: 1px solid transparent;
    border-radius: 8px;
    padding: 10px 11px;
    color: var(--color-muted);
    font-size: 0.9rem;
    font-weight: 800;
    text-decoration: none;
}

.legal-nav a:hover,
.legal-nav a[aria-current="page"] {
    border-color: rgb(245 184 0 / 28%);
    background: rgb(245 184 0 / 10%);
    color: var(--color-text);
}

.legal-article {
    max-width: 780px;
    border: 1px solid rgb(255 255 255 / 10%);
    border-radius: 8px;
    background: rgb(8 13 19 / 72%);
    padding: 34px;
}

.legal-article h2 {
    margin: 34px 0 12px;
    color: var(--color-text);
    font-size: 1.45rem;
    line-height: 1.18;
}

.legal-article h2:first-child {
    margin-top: 0;
}

.legal-article p,
.legal-article li {
    color: rgb(245 247 250 / 86%);
    font-size: 1rem;
    line-height: 1.78;
}

.legal-article ul,
.legal-article ol {
    padding-left: 22px;
}

.legal-article a {
    color: var(--color-accent-strong);
    font-weight: 800;
    text-decoration-thickness: 2px;
    text-underline-offset: 3px;
}

.listing-hero,
.detail-hero {
    margin-top: 24px;
    overflow: hidden;
    border: 1px solid rgb(255 255 255 / 12%);
    border-radius: 8px;
    background:
        radial-gradient(circle at 18% 0, rgb(245 184 0 / 15%), transparent 34%),
        linear-gradient(135deg, rgb(245 184 0 / 10%), rgb(255 255 255 / 0) 48%),
        linear-gradient(180deg, rgb(17 24 32 / 92%), rgb(8 13 19 / 88%));
    padding: clamp(32px, 5vw, 62px);
}

.detail-hero {
    padding: clamp(36px, 4.6vw, 76px);
}

.listing-hero--with-image {
    display: grid;
    min-height: clamp(260px, 31vw, 390px);
    align-content: end;
    background:
        linear-gradient(90deg, rgb(5 8 13 / 94%) 0%, rgb(5 8 13 / 78%) 48%, rgb(5 8 13 / 44%) 100%),
        linear-gradient(180deg, rgb(5 8 13 / 18%) 0%, rgb(5 8 13 / 76%) 100%),
        var(--listing-hero-image, linear-gradient(135deg, #111820, #05080d)),
        radial-gradient(circle at 18% 0, rgb(245 184 0 / 16%), transparent 34%),
        linear-gradient(180deg, rgb(17 24 32 / 94%), rgb(8 13 19 / 92%));
}

.listing-hero--with-image .eyebrow,
.listing-hero--with-image h1,
.listing-hero--with-image .lead {
    max-width: 740px;
}

.listing-hero--reviews {
    background:
        linear-gradient(90deg, rgb(5 8 13 / 95%) 0%, rgb(5 8 13 / 77%) 48%, rgb(5 8 13 / 42%) 100%),
        linear-gradient(180deg, rgb(5 8 13 / 20%) 0%, rgb(5 8 13 / 78%) 100%),
        var(--listing-hero-image, linear-gradient(135deg, rgb(22 20 16), rgb(8 13 19))),
        linear-gradient(135deg, rgb(245 184 0 / 16%), rgb(255 255 255 / 0) 42%),
        linear-gradient(180deg, rgb(22 20 16 / 96%), rgb(8 13 19 / 96%));
}

.listing-hero--games {
    background:
        linear-gradient(90deg, rgb(5 8 13 / 95%) 0%, rgb(5 8 13 / 78%) 48%, rgb(5 8 13 / 40%) 100%),
        linear-gradient(180deg, rgb(5 8 13 / 18%) 0%, rgb(5 8 13 / 78%) 100%),
        var(--listing-hero-image, linear-gradient(135deg, rgb(17 24 32), rgb(8 13 19))),
        linear-gradient(135deg, rgb(45 212 191 / 14%), rgb(245 184 0 / 8%) 50%, rgb(255 255 255 / 0)),
        linear-gradient(180deg, rgb(17 24 32 / 96%), rgb(8 13 19 / 96%));
}

.listing-hero--with-image {
    background-color: var(--color-bg-soft);
    background-position: center, center, right center, center, center;
    background-repeat: no-repeat;
    background-size: cover, cover, contain, cover, cover;
}

.detail-hero--game {
    background:
        linear-gradient(135deg, rgb(45 212 191 / 14%), rgb(245 184 0 / 8%) 50%, rgb(255 255 255 / 0)),
        linear-gradient(180deg, rgb(17 24 32 / 96%), rgb(8 13 19 / 96%));
}

.listing-hero--lumiri {
    background:
        linear-gradient(90deg, rgb(5 8 13 / 95%) 0%, rgb(5 8 13 / 78%) 48%, rgb(5 8 13 / 42%) 100%),
        linear-gradient(180deg, rgb(5 8 13 / 18%) 0%, rgb(5 8 13 / 78%) 100%),
        var(--listing-hero-image, linear-gradient(135deg, rgb(13 26 30), rgb(8 13 19))),
        linear-gradient(135deg, rgb(15 185 177 / 18%), rgb(245 184 0 / 10%) 44%, rgb(255 255 255 / 0)),
        linear-gradient(180deg, rgb(13 26 30 / 96%), rgb(8 13 19 / 96%));
}

.listing-hero--lumiri.listing-hero--with-image {
    background-color: var(--color-bg-soft);
    background-position: center, center, right center, center, center;
    background-repeat: no-repeat;
    background-size: cover, cover, contain, cover, cover;
}

.listing-hero--search {
    background:
        linear-gradient(90deg, rgb(5 8 13 / 95%) 0%, rgb(5 8 13 / 78%) 48%, rgb(5 8 13 / 42%) 100%),
        linear-gradient(180deg, rgb(5 8 13 / 18%) 0%, rgb(5 8 13 / 78%) 100%),
        var(--listing-hero-image, linear-gradient(135deg, rgb(17 24 32), rgb(8 13 19))),
        linear-gradient(135deg, rgb(59 130 246 / 13%), rgb(245 184 0 / 10%) 48%, rgb(255 255 255 / 0)),
        linear-gradient(180deg, rgb(17 24 32 / 96%), rgb(8 13 19 / 96%));
}

.listing-hero--search.listing-hero--with-image {
    background-color: var(--color-bg-soft);
    background-position: center, center, right center, center, center;
    background-repeat: no-repeat;
    background-size: cover, cover, contain, cover, cover;
}

.listing-hero--partners {
    background:
        linear-gradient(90deg, rgb(5 8 13 / 95%) 0%, rgb(5 8 13 / 78%) 48%, rgb(5 8 13 / 42%) 100%),
        linear-gradient(180deg, rgb(5 8 13 / 18%) 0%, rgb(5 8 13 / 78%) 100%),
        var(--listing-hero-image, linear-gradient(135deg, rgb(17 24 32), rgb(8 13 19))),
        linear-gradient(135deg, rgb(245 184 0 / 16%), rgb(34 197 94 / 8%) 46%, rgb(255 255 255 / 0)),
        linear-gradient(180deg, rgb(17 24 32 / 96%), rgb(8 13 19 / 96%));
}

.listing-hero--partners.listing-hero--with-image {
    background-color: var(--color-bg-soft);
    background-position: center, center, right center, center, center;
    background-repeat: no-repeat;
    background-size: cover, cover, contain, cover, cover;
}

.listing-hero--contact,
.listing-hero--submission,
.listing-hero--co-partners,
.listing-hero--redaktion {
    position: relative;
    isolation: isolate;
    display: grid;
    gap: 18px;
    min-height: clamp(270px, 33vw, 410px);
    align-content: end;
    background:
        linear-gradient(118deg, rgb(245 184 0 / 17%) 0%, rgb(245 184 0 / 4%) 30%, transparent 62%),
        linear-gradient(280deg, rgb(39 177 169 / 13%) 0%, transparent 48%),
        repeating-linear-gradient(112deg, rgb(255 255 255 / 4%) 0 1px, transparent 1px 28px),
        linear-gradient(180deg, rgb(17 24 32 / 96%), rgb(7 11 17 / 96%));
}

.listing-hero--contact {
    background:
        linear-gradient(90deg, rgb(5 8 13 / 95%) 0%, rgb(5 8 13 / 78%) 48%, rgb(5 8 13 / 42%) 100%),
        linear-gradient(180deg, rgb(5 8 13 / 18%) 0%, rgb(5 8 13 / 78%) 100%),
        var(--listing-hero-image, linear-gradient(135deg, rgb(17 24 32), rgb(8 13 19))),
        linear-gradient(118deg, rgb(245 184 0 / 17%) 0%, rgb(245 184 0 / 4%) 30%, transparent 62%),
        linear-gradient(180deg, rgb(17 24 32 / 96%), rgb(7 11 17 / 96%));
}

.listing-hero--contact.listing-hero--with-image {
    background-color: var(--color-bg-soft);
    background-position: center, center, right center, center, center;
    background-repeat: no-repeat;
    background-size: cover, cover, contain, cover, cover;
}

.listing-hero--submission {
    background:
        linear-gradient(90deg, rgb(5 8 13 / 95%) 0%, rgb(5 8 13 / 78%) 48%, rgb(5 8 13 / 42%) 100%),
        linear-gradient(180deg, rgb(5 8 13 / 18%) 0%, rgb(5 8 13 / 78%) 100%),
        var(--listing-hero-image, linear-gradient(135deg, rgb(13 26 30), rgb(7 11 17))),
        linear-gradient(118deg, rgb(39 177 169 / 18%) 0%, rgb(245 184 0 / 7%) 38%, transparent 68%),
        linear-gradient(180deg, rgb(13 26 30 / 96%), rgb(7 11 17 / 96%));
}

.listing-hero--submission.listing-hero--with-image {
    background-color: var(--color-bg-soft);
    background-position: center, center, right center, center, center;
    background-repeat: no-repeat;
    background-size: cover, cover, contain, cover, cover;
}

.listing-hero--co-partners {
    background:
        linear-gradient(90deg, rgb(5 8 13 / 95%) 0%, rgb(5 8 13 / 78%) 48%, rgb(5 8 13 / 42%) 100%),
        linear-gradient(180deg, rgb(5 8 13 / 18%) 0%, rgb(5 8 13 / 78%) 100%),
        var(--listing-hero-image, linear-gradient(135deg, rgb(17 24 32), rgb(8 13 19))),
        linear-gradient(118deg, rgb(245 184 0 / 16%) 0%, rgb(34 197 94 / 8%) 42%, transparent 70%),
        linear-gradient(180deg, rgb(17 24 32 / 96%), rgb(7 11 17 / 96%));
}

.listing-hero--co-partners.listing-hero--with-image {
    background-color: var(--color-bg-soft);
    background-position: center, center, right center, center, center;
    background-repeat: no-repeat;
    background-size: cover, cover, contain, cover, cover;
}

.listing-hero--redaktion {
    background:
        linear-gradient(90deg, rgb(5 8 13 / 95%) 0%, rgb(5 8 13 / 78%) 48%, rgb(5 8 13 / 42%) 100%),
        linear-gradient(180deg, rgb(5 8 13 / 18%) 0%, rgb(5 8 13 / 78%) 100%),
        var(--listing-hero-image, linear-gradient(135deg, rgb(17 24 32), rgb(8 13 19))),
        linear-gradient(118deg, rgb(245 184 0 / 15%) 0%, rgb(96 165 250 / 8%) 42%, transparent 70%),
        linear-gradient(180deg, rgb(17 24 32 / 96%), rgb(7 11 17 / 96%));
}

.listing-hero--redaktion.listing-hero--with-image {
    background-color: var(--color-bg-soft);
    background-position: center, center, right center, center, center;
    background-repeat: no-repeat;
    background-size: cover, cover, contain, cover, cover;
}

.listing-hero h1,
.detail-hero h1 {
    max-width: 980px;
    margin: 0;
    color: var(--color-text);
    font-size: clamp(2.2rem, 5vw, 4.6rem);
    line-height: 0.98;
}

.detail-hero time {
    display: inline-block;
    margin-top: 22px;
    color: var(--color-muted);
    font-size: 0.9rem;
    font-weight: 800;
    text-transform: uppercase;
}

.content-list {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
    margin-top: 24px;
}

.content-list__summary {
    grid-column: 1 / -1;
    margin: 0 0 2px;
    color: var(--color-muted);
    font-size: 0.92rem;
    font-weight: 800;
}

.content-section {
    margin-top: 34px;
}

.content-list--compact {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.content-filter {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 18px;
}

.content-filter a {
    border: 1px solid rgb(255 255 255 / 16%);
    border-radius: 4px;
    background: rgb(255 255 255 / 4%);
    color: var(--color-text);
    font-size: 0.84rem;
    font-weight: 900;
    padding: 9px 12px;
}

.content-filter a[aria-current="page"],
.content-filter a:hover,
.content-filter a:focus-visible {
    border-color: rgb(245 184 0 / 65%);
    background: rgb(245 184 0 / 14%);
    color: var(--color-accent-strong);
}

.content-pagination {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
    width: min(100% - 56px, var(--site-width));
    margin: 28px auto 0;
}

.content-pagination a,
.content-pagination span {
    min-width: 42px;
    border: 1px solid rgb(255 255 255 / 16%);
    border-radius: 4px;
    background: rgb(255 255 255 / 4%);
    color: var(--color-text);
    font-size: 0.84rem;
    font-weight: 900;
    line-height: 1;
    padding: 11px 12px;
    text-align: center;
}

.content-pagination a:hover,
.content-pagination a:focus-visible,
.content-pagination span[aria-current="page"] {
    border-color: rgb(245 184 0 / 65%);
    background: rgb(245 184 0 / 14%);
    color: var(--color-accent-strong);
}

.review-statistics {
    display: grid;
    gap: 18px;
}

.review-statistics-filter {
    display: grid;
    grid-template-columns: repeat(5, minmax(130px, 1fr)) auto auto;
    gap: 12px;
    align-items: end;
    border: 1px solid rgb(255 255 255 / 12%);
    border-radius: 8px;
    background: rgb(255 255 255 / 4%);
    padding: 14px;
}

.review-statistics-filter label {
    display: grid;
    gap: 6px;
    color: var(--color-muted);
    font-size: 0.82rem;
    font-weight: 800;
}

.review-statistics-filter input,
.review-statistics-filter select {
    min-height: 40px;
    border: 1px solid rgb(255 255 255 / 14%);
    border-radius: 5px;
    background: var(--color-bg-soft);
    color: var(--color-text);
    padding: 8px 10px;
}

.review-statistics-cards {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
}

.review-statistics-cards article,
.review-statistics-panel {
    border: 1px solid rgb(255 255 255 / 12%);
    border-radius: 8px;
    background: linear-gradient(180deg, rgb(17 24 32 / 94%), rgb(9 14 20 / 94%));
    box-shadow: 0 1px 0 rgb(255 255 255 / 4%) inset;
    padding: 18px;
}

.review-statistics-cards span,
.review-statistics-category-grid small,
.review-statistics-trend small {
    color: var(--color-muted);
    font-size: 0.85rem;
}

.review-statistics-cards strong {
    display: block;
    margin-top: 8px;
    color: var(--color-accent-strong);
    font-size: 2rem;
    line-height: 1;
}

.review-statistics-panel h2 {
    margin: 0 0 14px;
    font-size: 1.05rem;
}

.review-statistics-category-grid,
.review-statistics-trend {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(145px, 1fr));
    gap: 10px;
}

.review-statistics-category-grid span,
.review-statistics-trend span {
    display: grid;
    gap: 4px;
    border: 1px solid rgb(255 255 255 / 10%);
    border-radius: 6px;
    background: rgb(255 255 255 / 4%);
    padding: 12px;
}

.review-statistics-bars {
    display: grid;
    gap: 8px;
}

.review-statistics-bars div {
    display: grid;
    grid-template-columns: 46px 1fr 44px;
    gap: 10px;
    align-items: center;
}

.review-statistics-bars meter {
    width: 100%;
    min-height: 12px;
}

.review-statistics-columns {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.review-statistics-list {
    display: grid;
    gap: 10px;
    margin: 0;
    padding-left: 1.35rem;
}

.review-statistics-list li {
    padding-left: 0.25rem;
}

.review-statistics-list li::marker {
    color: var(--color-accent);
    font-weight: 900;
}

.review-statistics-list a {
    color: var(--color-text);
}

.review-statistics-list strong,
.review-statistics-list time {
    display: block;
    color: var(--color-muted);
    font-size: 0.86rem;
    margin-top: 2px;
}

.content-card {
    display: grid;
    min-width: 0;
    overflow: hidden;
    border: 1px solid rgb(255 255 255 / 12%);
    border-radius: 6px;
    background: linear-gradient(180deg, rgb(17 24 32 / 94%), rgb(9 14 20 / 94%));
    box-shadow: 0 1px 0 rgb(255 255 255 / 4%) inset;
}

.content-card:hover,
.content-card:focus-visible {
    border-color: rgb(245 184 0 / 55%);
}

.content-card__media {
    position: relative;
    aspect-ratio: 16 / 9;
    min-height: 166px;
    overflow: hidden;
    background: var(--color-bg-soft);
}

.content-card__media img {
    display: block;
    width: 100%;
    height: 100%;
    min-height: 166px;
    object-fit: cover;
    object-position: center;
}

.content-card__body {
    display: grid;
    gap: 12px;
    min-width: 0;
    padding: 16px;
}

.content-card__body strong {
    color: var(--color-text);
    font-size: clamp(1.1rem, 1.6vw, 1.45rem);
    line-height: 1.1;
}

.content-card__body > span:not(.content-label, .meta-row, .mini-tags) {
    color: var(--color-muted);
}

.content-card time {
    color: var(--color-muted);
    font-size: 0.84rem;
}

.mini-tags,
.tag-cloud {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.mini-tags span,
.tag-cloud span,
.tag-cloud a {
    border: 1px solid rgb(255 255 255 / 16%);
    border-radius: 4px;
    background: rgb(255 255 255 / 4%);
    color: var(--color-text);
    font-size: 0.78rem;
    font-weight: 800;
    padding: 6px 8px;
}

.empty-state {
    grid-column: 1 / -1;
    border: 1px solid rgb(255 255 255 / 12%);
    border-radius: 6px;
    background: linear-gradient(180deg, rgb(17 24 32 / 94%), rgb(9 14 20 / 94%));
    padding: 28px;
}

.empty-state h2,
.info-panel h2,
.verdict-box h2 {
    margin: 0;
    color: var(--color-text);
    font-size: 1rem;
    text-transform: uppercase;
}

.empty-state p,
.info-panel p {
    margin: 10px 0 0;
    color: var(--color-muted);
}

.article-detail {
    width: min(1680px, calc(100% - 56px));
    padding-top: 0;
}

.detail-media {
    margin: 28px 0 0;
    overflow: hidden;
    border: 1px solid rgb(255 255 255 / 12%);
    border-radius: 8px;
    background: var(--color-bg-soft);
    box-shadow: 0 22px 70px rgb(0 0 0 / 36%);
}

.detail-media img {
    width: 100%;
    aspect-ratio: 16 / 8;
    max-height: 680px;
    object-fit: cover;
}

.page-review-show .detail-media img {
    aspect-ratio: 16 / 9;
    max-height: 640px;
    object-fit: contain;
}

.lumiri-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
    margin-top: 24px;
}

.lumiri-grid--faq {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.lumiri-grid__heading {
    grid-column: 1 / -1;
    margin-bottom: 0;
}

.article-layout,
.review-detail-grid,
.game-layout {
    display: grid;
    gap: clamp(18px, 1.7vw, 28px);
    margin-top: 28px;
}

.article-layout {
    grid-template-columns: minmax(0, 1fr) minmax(240px, 300px);
}

.article-body-column {
    display: grid;
    align-content: start;
    gap: 16px;
    min-width: 0;
}

.review-detail-grid {
    grid-template-columns: minmax(150px, 190px) minmax(0, 1fr) minmax(220px, 280px);
    align-items: start;
}

.game-layout {
    grid-template-columns: minmax(0, 1fr) minmax(280px, 340px);
}

.content-prose,
.info-panel,
.review-score-panel,
.verdict-box {
    border: 1px solid rgb(255 255 255 / 12%);
    border-radius: 6px;
    background: linear-gradient(180deg, rgb(17 24 32 / 94%), rgb(9 14 20 / 94%));
    box-shadow: 0 1px 0 rgb(255 255 255 / 4%) inset;
}

.content-prose {
    color: #e8edf3;
    font-size: clamp(1rem, 1.25vw, 1.08rem);
    line-height: 1.78;
    padding: clamp(24px, 4vw, 42px);
}

.content-prose > p,
.content-prose > ul,
.content-prose > ol,
.content-prose > blockquote,
.content-prose > h2,
.content-prose > h3,
.content-prose > h4 {
    max-width: 96ch;
}

.content-prose > p:has(> img:only-child) {
    max-width: none;
}

.content-prose p:first-child,
.verdict-box p:first-child {
    margin-top: 0;
}

.content-prose p:last-child,
.verdict-box p:last-child {
    margin-bottom: 0;
}

.detail-aside {
    display: grid;
    align-content: start;
    gap: 16px;
}

.info-panel,
.review-score-panel,
.verdict-box {
    display: grid;
    gap: 14px;
    padding: 18px;
}

.ai-disclosure {
    border-color: rgb(15 185 177 / 34%);
    background:
        linear-gradient(135deg, rgb(15 185 177 / 10%), rgb(245 184 0 / 6%)),
        linear-gradient(180deg, rgb(17 24 32 / 94%), rgb(9 14 20 / 94%));
}

.ai-disclosure h2 {
    color: #c8fff7;
}

.review-score-panel {
    justify-items: start;
    position: sticky;
    top: 18px;
}

.review-purchase {
    display: grid;
    gap: 10px;
    width: 100%;
}

.review-purchase__primary {
    justify-content: center;
    width: 100%;
    text-align: center;
}

.review-purchase__secondary {
    display: grid;
    gap: 8px;
}

.review-purchase__secondary a {
    border: 1px solid rgb(255 255 255 / 16%);
    border-radius: 4px;
    background: rgb(255 255 255 / 4%);
    color: var(--color-accent);
    font-size: 0.85rem;
    font-weight: 900;
    padding: 9px 10px;
    text-align: center;
}

.comment-section {
    display: grid;
    gap: 22px;
    margin-top: 32px;
    margin-bottom: 32px;
    padding: clamp(20px, 3vw, 30px);
    border: 1px solid rgb(255 255 255 / 12%);
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgb(245 184 0 / 5%), transparent 34%),
        linear-gradient(180deg, rgb(17 24 32 / 96%), rgb(7 11 16 / 96%));
    box-shadow: 0 22px 60px rgb(0 0 0 / 28%);
}

.comment-section__header {
    display: grid;
    gap: 6px;
    padding-bottom: 4px;
}

.comment-section__header h2 {
    margin: 0;
    color: var(--color-text);
    font-size: clamp(1.35rem, 2vw, 1.8rem);
}

.comment-section__empty,
.comment-section__closed,
.comment-disqus noscript {
    margin: 0;
    color: var(--color-muted);
}

.comment-list {
    display: grid;
    gap: 14px;
}

.comment-card {
    display: grid;
    gap: 10px;
    padding: 16px;
    border: 1px solid rgb(255 255 255 / 10%);
    border-radius: 6px;
    background: rgb(255 255 255 / 4%);
}

.comment-card--reply {
    background: rgb(255 255 255 / 3%);
}

.comment-card__meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 12px;
    align-items: baseline;
    justify-content: space-between;
}

.comment-card__meta strong {
    color: var(--color-text);
}

.comment-card__meta time {
    color: var(--color-muted);
    font-size: 0.82rem;
}

.comment-card__body {
    margin: 0;
    color: #dce5ef;
    line-height: 1.65;
}

.comment-card__replies {
    display: grid;
    gap: 10px;
    margin-top: 4px;
    padding-left: 16px;
    border-left: 2px solid rgb(245 184 0 / 34%);
}

.comment-form {
    display: grid;
    gap: 18px;
    max-width: 860px;
    padding-top: 4px;
}

.comment-form__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.comment-form__field {
    display: grid;
    gap: 8px;
}

.comment-form label {
    color: var(--color-text);
    font-size: 0.84rem;
    font-weight: 900;
    letter-spacing: 0;
}

.comment-form input,
.comment-form textarea {
    width: 100%;
    border: 1px solid rgb(255 255 255 / 16%);
    border-radius: 6px;
    background: rgb(5 8 13 / 62%);
    box-shadow: inset 0 1px 0 rgb(255 255 255 / 4%);
    color: var(--color-text);
    font: inherit;
    line-height: 1.5;
    padding: 13px 14px;
    transition: border-color 160ms ease, background-color 160ms ease, box-shadow 160ms ease;
}

.comment-form input::placeholder,
.comment-form textarea::placeholder {
    color: rgb(154 164 175 / 74%);
}

.comment-form input:hover,
.comment-form textarea:hover {
    border-color: rgb(255 255 255 / 26%);
    background: rgb(255 255 255 / 6%);
}

.comment-form input:focus,
.comment-form textarea:focus {
    outline: 2px solid rgb(245 184 0 / 34%);
    border-color: var(--color-accent);
    background: rgb(5 8 13 / 76%);
    box-shadow: 0 0 0 5px rgb(245 184 0 / 9%), inset 0 1px 0 rgb(255 255 255 / 5%);
}

.comment-form textarea {
    min-height: 150px;
    resize: vertical;
}

.comment-form__consent {
    display: grid;
    gap: 8px;
    max-width: 760px;
    border: 1px solid rgb(255 255 255 / 10%);
    border-radius: 6px;
    background: rgb(255 255 255 / 4%);
    padding: 12px 14px;
}

.comment-form__checkbox {
    display: flex;
    gap: 10px;
    align-items: flex-start;
}

.comment-form__checkbox input[type="checkbox"] {
    flex: 0 0 auto;
    width: 18px;
    height: 18px;
    margin-top: 2px;
    accent-color: var(--color-accent);
}

.comment-form__checkbox label {
    color: #dce5ef;
    font-size: 0.86rem;
    font-weight: 700;
    line-height: 1.45;
}

.comment-form__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px 16px;
    align-items: center;
}

.comment-form__submit {
    min-width: min(100%, 260px);
}

.comment-form__actions p {
    margin: 0;
    color: var(--color-muted);
    font-size: 0.84rem;
}

.comment-form__trap {
    position: absolute;
    left: -10000px;
    width: 1px;
    height: 1px;
    overflow: hidden;
}

.comment-form ul {
    margin: 0;
    padding-left: 18px;
    color: #fecaca;
    font-size: 0.84rem;
}

.comment-form__errors {
    border: 1px solid rgb(239 68 68 / 46%);
    border-radius: 6px;
    background: rgb(239 68 68 / 8%);
    padding: 12px 14px;
}

.comment-disqus {
    min-height: 180px;
}

.score-badge--large {
    width: 104px;
    min-height: 112px;
}

.score-badge--large strong {
    font-size: 2.45rem;
}

.fact-list {
    display: grid;
    gap: 12px;
    margin: 0;
}

.fact-list div {
    display: grid;
    gap: 3px;
}

.fact-list dt {
    color: var(--color-muted);
    font-size: 0.75rem;
    font-weight: 900;
    text-transform: uppercase;
}

.fact-list dd {
    margin: 0;
    color: var(--color-text);
    font-weight: 800;
}

.fact-list--wide {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.verdict-box {
    margin-top: 28px;
}

.verdict-box p {
    margin: 0;
    color: #e8edf3;
}

.store-links {
    display: grid;
    gap: 10px;
}

.store-links a {
    border: 1px solid rgb(255 255 255 / 16%);
    border-radius: 4px;
    background: rgb(255 255 255 / 4%);
    color: var(--color-accent);
    font-weight: 900;
    padding: 10px 12px;
}

.about-page {
    display: grid;
    gap: 24px;
}

.about-hero {
    display: grid;
    align-content: end;
    min-height: clamp(300px, 35vw, 440px);
    margin-top: 24px;
    overflow: hidden;
    border: 1px solid rgb(255 255 255 / 12%);
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgb(45 212 191 / 14%), rgb(245 184 0 / 10%) 44%, rgb(255 255 255 / 0)),
        linear-gradient(180deg, rgb(17 24 32 / 96%), rgb(8 13 19 / 96%));
    padding: clamp(34px, 6vw, 72px);
}

.about-hero--with-image {
    background:
        linear-gradient(90deg, rgb(5 8 13 / 95%) 0%, rgb(5 8 13 / 78%) 48%, rgb(5 8 13 / 42%) 100%),
        linear-gradient(180deg, rgb(5 8 13 / 18%) 0%, rgb(5 8 13 / 78%) 100%),
        var(--listing-hero-image, linear-gradient(135deg, rgb(17 24 32), rgb(8 13 19))),
        linear-gradient(135deg, rgb(45 212 191 / 14%), rgb(245 184 0 / 10%) 44%, rgb(255 255 255 / 0)),
        linear-gradient(180deg, rgb(17 24 32 / 96%), rgb(8 13 19 / 96%));
    background-color: var(--color-bg-soft);
    background-position: center, center, right center, center, center;
    background-repeat: no-repeat;
    background-size: cover, cover, contain, cover, cover;
}

.about-hero h1 {
    max-width: 840px;
    margin: 0;
    color: var(--color-text);
    font-size: clamp(2.4rem, 6vw, 5rem);
    line-height: 0.98;
}

.about-hero__facts {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 28px;
}

.about-hero__facts span {
    border: 1px solid rgb(255 255 255 / 18%);
    border-radius: 4px;
    background: rgb(255 255 255 / 5%);
    color: var(--color-text);
    font-size: 0.82rem;
    font-weight: 900;
    padding: 8px 10px;
    text-transform: uppercase;
}

.about-pillars {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
}

.about-pillars article,
.about-story,
.about-lumiri,
.about-timeline {
    border: 1px solid rgb(255 255 255 / 12%);
    border-radius: 6px;
    background: linear-gradient(180deg, rgb(17 24 32 / 94%), rgb(9 14 20 / 94%));
    box-shadow: 0 1px 0 rgb(255 255 255 / 4%) inset;
}

.about-pillars article {
    display: grid;
    align-content: start;
    gap: 12px;
    min-height: 210px;
    padding: 18px;
}

.about-pillars h2,
.about-story h2,
.about-lumiri h2,
.about-timeline h2 {
    margin: 0;
    color: var(--color-text);
    font-size: 1.12rem;
    line-height: 1.1;
    text-transform: uppercase;
}

.about-pillars p,
.about-story p,
.about-lumiri p {
    margin: 0;
    color: var(--color-muted);
}

.about-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
    gap: 24px;
}

.about-story,
.about-lumiri,
.about-timeline {
    display: grid;
    gap: 16px;
    padding: clamp(20px, 3vw, 28px);
}

.about-story p {
    max-width: 860px;
    color: #dbe2ea;
    font-size: 1.02rem;
    line-height: 1.75;
}

.about-lumiri {
    background:
        linear-gradient(145deg, rgb(11 77 74 / 36%), rgb(8 13 19 / 96%) 54%, rgb(28 23 15 / 78%)),
        var(--color-surface);
}

.about-lumiri__image {
    display: block;
    width: 100%;
    aspect-ratio: 2 / 1;
    overflow: hidden;
    border: 1px solid rgb(255 255 255 / 12%);
    border-radius: 5px;
    object-fit: cover;
    object-position: center;
    box-shadow: 0 1px 0 rgb(255 255 255 / 5%) inset;
}

.about-timeline {
    margin-bottom: 8px;
}

.about-timeline ol {
    display: grid;
    gap: 14px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.about-timeline li {
    display: grid;
    grid-template-columns: 92px minmax(0, 1fr);
    gap: 18px;
    align-items: start;
    border-top: 1px solid rgb(255 255 255 / 9%);
    padding-top: 14px;
}

.about-timeline time {
    color: var(--color-accent);
    font-size: 1.1rem;
    font-weight: 950;
    line-height: 1;
}

.about-timeline span {
    color: #e8edf3;
    font-weight: 700;
    line-height: 1.35;
}

.partner-page {
    display: grid;
    gap: 28px;
}

.partner-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
    gap: 24px;
}

.partner-application,
.partner-guidelines,
.partner-directory > div {
    border: 1px solid rgb(255 255 255 / 12%);
    border-radius: 6px;
    background: linear-gradient(180deg, rgb(17 24 32 / 94%), rgb(9 14 20 / 94%));
    box-shadow: 0 1px 0 rgb(255 255 255 / 4%) inset;
}

.partner-application,
.partner-guidelines {
    display: grid;
    align-content: start;
    gap: 16px;
    padding: clamp(20px, 3vw, 28px);
}

.partner-application h2,
.partner-guidelines h2,
.partner-directory h2 {
    margin: 0;
    color: var(--color-text);
    font-size: 1.12rem;
    line-height: 1.1;
    text-transform: uppercase;
}

.partner-application p,
.partner-guidelines li,
.partner-empty {
    color: var(--color-muted);
}

.privacy-note,
.notice {
    border: 1px solid rgb(255 255 255 / 12%);
    border-radius: 6px;
    background: rgb(255 255 255 / 5%);
    padding: 14px;
}

.privacy-note strong {
    color: var(--color-text);
}

.privacy-note p {
    margin: 8px 0 0;
}

.notice--success {
    border-color: rgb(34 197 94 / 42%);
    color: #bbf7d0;
}

.notice--danger {
    border-color: rgb(239 68 68 / 46%);
    color: #fecaca;
}

.partner-form {
    display: grid;
    gap: 15px;
}

.partner-form label {
    display: grid;
    gap: 8px;
    color: var(--color-text);
    font-weight: 800;
}

.partner-form input {
    width: 100%;
    border: 1px solid rgb(255 255 255 / 16%);
    border-radius: 4px;
    background: rgb(255 255 255 / 5%);
    color: var(--color-text);
    padding: 12px 13px;
}

.partner-form input:focus {
    outline: 2px solid rgb(245 184 0 / 34%);
    border-color: var(--color-accent);
}

.partner-form input[type="checkbox"] {
    width: auto;
}

.partner-form__trap {
    position: absolute;
    left: -10000px;
    width: 1px;
    height: 1px;
    overflow: hidden;
}

.partner-directory {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 24px;
    padding-bottom: 14px;
}

.partner-directory > div {
    display: grid;
    align-content: start;
    gap: 16px;
    padding: clamp(20px, 3vw, 28px);
}

.partner-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.partner-link-card {
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
    border: 1px solid rgb(255 255 255 / 12%);
    border-radius: 6px;
    background: rgb(255 255 255 / 4%);
    color: var(--color-text);
    font-weight: 900;
    padding: 12px;
}

.partner-link-card img {
    flex: 0 0 auto;
    width: 42px;
    height: 42px;
    border-radius: 5px;
    object-fit: contain;
    background: rgb(255 255 255 / 8%);
}

.partner-link-card span {
    min-width: 0;
    overflow-wrap: anywhere;
}

.inbound-page,
.co-partner-page {
    display: grid;
    gap: clamp(26px, 4vw, 42px);
}

.inbound-hero-strip {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 6px;
}

.inbound-hero-strip span {
    border: 1px solid rgb(245 184 0 / 24%);
    border-radius: 999px;
    background: rgb(5 8 13 / 42%);
    color: var(--color-text);
    font-size: 0.82rem;
    font-weight: 850;
    line-height: 1;
    padding: 10px 12px;
    box-shadow: 0 1px 0 rgb(255 255 255 / 5%) inset;
}

.inbound-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(300px, 390px);
    gap: clamp(20px, 3vw, 30px);
    align-items: start;
}

.inbound-panel,
.inbound-aside {
    border: 1px solid rgb(255 255 255 / 12%);
    border-radius: 8px;
    background:
        linear-gradient(180deg, rgb(255 255 255 / 4%), transparent 32%),
        linear-gradient(180deg, rgb(17 24 32 / 96%), rgb(8 13 19 / 96%));
    box-shadow: var(--shadow-panel), 0 1px 0 rgb(255 255 255 / 5%) inset;
    padding: clamp(22px, 3vw, 34px);
}

.inbound-panel {
    display: grid;
    gap: 20px;
}

.inbound-aside {
    position: sticky;
    top: 96px;
    align-content: start;
    display: grid;
    gap: 18px;
}

.inbound-panel__header {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 14px;
    align-items: start;
}

.inbound-panel__mark {
    display: grid;
    place-items: center;
    min-width: 42px;
    height: 42px;
    border: 1px solid rgb(245 184 0 / 30%);
    border-radius: 8px;
    background: rgb(245 184 0 / 9%);
    color: var(--color-accent);
    font-size: 0.76rem;
    font-weight: 950;
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.inbound-panel__header h2 {
    margin: 0;
    color: var(--color-text);
    font-size: clamp(1.22rem, 1.8vw, 1.55rem);
    line-height: 1.1;
}

.inbound-panel__header p {
    margin: 7px 0 0;
    color: var(--color-muted);
    font-size: 0.94rem;
    line-height: 1.55;
}

.inbound-aside ul {
    display: grid;
    gap: 12px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.inbound-aside li {
    position: relative;
    color: var(--color-muted);
    padding-left: 22px;
    line-height: 1.55;
}

.inbound-aside li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.68em;
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: var(--color-accent);
    box-shadow: 0 0 0 4px rgb(245 184 0 / 10%);
}

.inbound-form {
    display: grid;
    gap: 16px;
}

.inbound-form__grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.inbound-form label {
    display: grid;
    gap: 8px;
    color: var(--color-text);
    font-size: 0.9rem;
    font-weight: 850;
}

.inbound-form input,
.inbound-form select,
.inbound-form textarea {
    width: 100%;
    border: 1px solid rgb(255 255 255 / 16%);
    border-radius: 7px;
    background: rgb(5 8 13 / 42%);
    color: var(--color-text);
    font: inherit;
    line-height: 1.45;
    padding: 13px 14px;
    transition: border-color 160ms ease, background-color 160ms ease, box-shadow 160ms ease;
}

.inbound-form input:hover,
.inbound-form select:hover,
.inbound-form textarea:hover {
    border-color: rgb(255 255 255 / 25%);
    background: rgb(255 255 255 / 6%);
}

.inbound-form select[multiple] {
    min-height: 130px;
}

.inbound-form textarea {
    resize: vertical;
}

.inbound-form input:focus,
.inbound-form select:focus,
.inbound-form textarea:focus {
    outline: 2px solid rgb(245 184 0 / 34%);
    border-color: var(--color-accent);
    box-shadow: 0 0 0 5px rgb(245 184 0 / 9%);
}

.inbound-form input[type="checkbox"] {
    width: auto;
    accent-color: var(--color-accent);
}

.inbound-form__trap {
    position: absolute;
    left: -10000px;
    width: 1px;
    height: 1px;
    overflow: hidden;
}

.co-partner-grid,
.author-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: clamp(16px, 2vw, 22px);
}

.co-partner-card,
.author-card {
    display: grid;
    align-content: start;
    gap: 16px;
    border: 1px solid rgb(255 255 255 / 12%);
    border-radius: 8px;
    background:
        linear-gradient(180deg, rgb(255 255 255 / 5%), transparent 34%),
        linear-gradient(180deg, rgb(17 24 32 / 94%), rgb(8 13 19 / 94%));
    color: var(--color-text);
    min-width: 0;
    min-height: 100%;
    padding: 20px;
    box-shadow: 0 1px 0 rgb(255 255 255 / 4%) inset;
    transition: border-color 160ms ease, transform 160ms ease, background-color 160ms ease;
}

.co-partner-card:hover,
.co-partner-card:focus-visible,
.author-card:hover,
.author-card:focus-visible {
    border-color: rgb(245 184 0 / 42%);
    transform: translateY(-2px);
}

.co-partner-card__top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 14px;
}

.co-partner-card__arrow {
    display: grid;
    place-items: center;
    width: 34px;
    height: 34px;
    border: 1px solid rgb(255 255 255 / 12%);
    border-radius: 999px;
    color: var(--color-accent);
    font-size: 0.98rem;
    font-weight: 900;
}

.co-partner-card__logo,
.author-card__avatar {
    display: grid;
    place-items: center;
    width: 72px;
    height: 72px;
    border: 1px solid rgb(255 255 255 / 12%);
    border-radius: 8px;
    background:
        linear-gradient(135deg, rgb(245 184 0 / 14%), transparent 62%),
        rgb(255 255 255 / 7%);
    color: var(--color-accent);
    font-size: 1.65rem;
    font-weight: 950;
}

.co-partner-card__logo img,
.author-card__avatar img {
    width: 100%;
    height: 100%;
    border-radius: 5px;
    object-fit: contain;
}

.author-card__avatar img {
    object-fit: cover;
}

.author-card .content-card__body,
.co-partner-card .content-card__body {
    gap: 8px;
    padding: 0;
}

.author-card .author-card__link {
    display: inline-flex;
    align-items: center;
    justify-self: start;
    margin-top: 6px;
    color: var(--color-accent);
    font-size: 0.88rem;
    font-weight: 900;
}

.theme-preview {
    padding-block: 36px 72px;
}

.theme-preview__hero {
    display: grid;
    gap: 22px;
    padding-block: 46px;
}

.theme-preview__hero h1 {
    max-width: 860px;
    margin: 0;
    font-size: clamp(2.6rem, 8vw, 5.6rem);
    line-height: .95;
}

.theme-preview__hero p {
    max-width: 680px;
    margin: 0;
    color: var(--color-muted);
    font-size: 1.05rem;
    line-height: 1.7;
}

.theme-preview__image {
    position: relative;
    width: min(100%, 920px);
    margin: 6px 0 0;
    overflow: hidden;
    border: 1px solid var(--color-surface-border);
    background: var(--color-surface);
}

.theme-preview__image::before {
    position: absolute;
    inset: 0;
    z-index: 1;
    content: "";
    pointer-events: none;
    background: var(--theme-hero-pattern), var(--theme-hero-glow);
    opacity: 0.7;
}

.theme-preview__image img {
    display: block;
    width: 100%;
    aspect-ratio: 16 / 7;
    object-fit: cover;
}

.theme-preview__meta {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
    margin: 10px 0 0;
}

.theme-preview__meta div {
    min-width: 0;
    padding: 16px;
    border: 1px solid var(--color-surface-border);
    background: rgb(255 255 255 / 4%);
}

.theme-preview__meta dt {
    color: var(--color-muted);
    font-size: .78rem;
    font-weight: 800;
    text-transform: uppercase;
}

.theme-preview__meta dd {
    margin: 8px 0 0;
    color: var(--color-text);
    overflow-wrap: anywhere;
}

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

.theme-preview__sample {
    display: grid;
    gap: 18px;
}

@media (max-width: 1320px) {
    .page-rating-guide .page-card-grid {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
}

@media (max-width: 1100px) {
    .main-nav {
        display: none;
    }

    .site-mobile-toggle {
        display: inline-flex;
    }

    .site-mobile-menu {
        display: block;
    }

    .portal-hero {
        --portal-hero-media-width: clamp(300px, 34vw, 400px);
        --portal-hero-content-width: min(620px, calc(100% - var(--portal-hero-media-width) - 96px));
    }

    .portal-hero,
    .content-grid {
        grid-template-columns: 1fr;
    }

    .portal-hero__side {
        border-top: 1px solid rgb(255 255 255 / 10%);
        border-left: 0;
    }

    .review-summary {
        grid-template-columns: 124px 1fr 1fr;
    }

    .review-summary .button {
        grid-column: 2 / -1;
        justify-self: start;
    }

    .review-carousel__track {
        grid-auto-columns: minmax(230px, 46%);
    }

    .discovery-nav,
    .card-grid--reviews,
    .card-grid--articles,
    .content-list,
    .review-statistics-cards,
    .review-statistics-columns,
    .tech-review-showcase__layout,
    .tech-review-showcase__lead,
    .lumiri-grid,
    .topic-rail,
    .site-footer__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .review-statistics-filter {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .article-layout,
    .review-detail-grid,
    .game-layout,
    .about-layout,
    .partner-layout,
    .inbound-layout,
    .legal-layout {
        grid-template-columns: 1fr;
    }

    .inbound-aside {
        position: static;
    }

    .legal-nav {
        position: static;
    }

    .article-layout {
        justify-content: stretch;
    }

    .review-score-panel {
        position: static;
    }

    .about-pillars {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .indie-radar__layout {
        grid-template-columns: 1fr;
    }

    .theme-preview__meta {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .redaktion-shell,
    .redaktion-form__grid,
    .redaktion-editor__grid,
    .redaktion-media-edit,
    .redaktion-grid,
    .redaktion-grid--two,
    .page-block--hero-media,
    .page-block--two-columns,
    .page-card-grid,
    .co-partner-grid,
    .author-grid {
        grid-template-columns: 1fr;
    }

    .redaktion-form-toolbar {
        position: static;
        align-items: stretch;
        flex-direction: column;
    }

    .redaktion-form-toolbar__actions,
    .redaktion-form-toolbar .redaktion-button {
        width: 100%;
    }

    .redaktion-form-toolbar__actions {
        align-items: stretch;
        flex-direction: column;
    }

    .redaktion-sidebar {
        border-right: 0;
        border-bottom: 1px solid var(--color-surface-border);
    }

    .redaktion-nav {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .redaktion-table {
        overflow-x: auto;
    }

    .redaktion-table__head,
    .redaktion-table__row {
        min-width: 760px;
    }

    .page-rating-guide .page-card-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 720px) {
    .page-rating-guide .page-card-grid {
        grid-template-columns: 1fr;
    }

    .page-rating-guide .page-block--hero-media {
        aspect-ratio: auto;
        min-height: 0;
        padding: 14px;
    }

    .page-rating-guide .page-block--hero-media > div {
        padding: 18px;
    }

    .page-rating-guide .page-block--hero h1 {
        font-size: clamp(2.1rem, 11vw, 3rem);
    }

    .wysiwyg-toolbar {
        max-height: 38vh;
        align-content: flex-start;
        overflow-y: auto;
        overscroll-behavior: contain;
    }

    .site-container {
        width: min(100% - 28px, var(--site-width));
    }

    .legal-page {
        width: min(100% - 28px, 1180px);
    }

    .legal-hero {
        display: grid;
        gap: 20px;
        padding: 24px 18px;
    }

    .legal-hero h1 {
        font-size: clamp(1.95rem, 8vw, 2.35rem);
        line-height: 1.04;
    }

    .legal-hero__lead,
    .legal-article p,
    .legal-article li {
        font-size: 0.96rem;
    }

    .legal-layout {
        gap: 18px;
        margin-block: 20px 42px;
    }

    .legal-nav,
    .legal-article {
        padding: 18px;
    }

    .legal-nav nav {
        grid-template-columns: 1fr;
    }

    .article-detail {
        width: min(100% - 28px, 1680px);
    }

    .detail-hero {
        padding: 24px 18px;
    }

    .detail-media img {
        aspect-ratio: 16 / 10;
    }

    .content-prose,
    .info-panel,
    .review-score-panel,
    .verdict-box {
        border-radius: 8px;
    }

    .comment-section {
        padding: 18px;
    }

    .comment-form__grid {
        grid-template-columns: 1fr;
    }

    .comment-form__actions {
        align-items: stretch;
        flex-direction: column;
    }

    .comment-form__submit {
        width: 100%;
    }

    .comment-card__replies {
        padding-left: 12px;
    }

    .site-header__top {
        display: none;
    }

    .site-header__main {
        min-height: 66px;
    }

    .site-logo img {
        max-width: 190px;
        max-height: 52px;
    }

    .portal-hero {
        --portal-hero-height: 850px;
        --portal-hero-content-width: min(100% - 28px, 760px);

        width: min(100% - 28px, var(--site-width));
        margin-top: 14px;
    }

    .portal-hero__media {
        top: 14px;
        right: 14px;
        bottom: auto;
        left: 14px;
        width: auto;
        min-width: 0;
        height: auto;
        opacity: 0.78;
        transform: none;
    }

    .portal-hero__media--theme img {
        padding: 0;
    }

    .portal-hero__season {
        top: 24px;
        right: 24px;
        max-width: min(180px, calc(100% - 48px));
        padding: 9px 11px;
    }

    .portal-hero__content {
        width: var(--portal-hero-content-width);
        min-height: var(--portal-hero-height);
        justify-content: flex-end;
        margin-inline: auto;
        padding-block: 260px 46px;
    }

    .portal-hero__title {
        display: block;
        min-height: 0;
        font-size: clamp(2.3rem, 2.9rem, 3.1rem);
    }

    .portal-hero__lead {
        min-height: 0;
    }

    .review-summary {
        grid-template-columns: 1fr;
        gap: 18px;
        min-height: 0;
    }

    .review-summary .button {
        grid-column: auto;
        justify-self: stretch;
        width: 100%;
    }

    .score-badge {
        width: 112px;
        height: auto;
        min-height: 112px;
    }

    .score-badge-wrap {
        width: min(100%, 112px);
    }

    .review-carousel__track {
        grid-auto-columns: minmax(230px, 86%);
    }

    .card-grid--reviews,
    .card-grid--articles,
    .content-list,
    .review-statistics-filter,
    .review-statistics-cards,
    .review-statistics-columns,
    .tech-review-showcase__layout,
    .tech-review-showcase__lead,
    .fact-list--wide,
    .inbound-form__grid,
    .partner-directory,
    .partner-list,
    .co-partner-grid,
    .author-grid,
    .about-pillars,
    .discovery-nav,
    .lumiri-grid,
    .topic-rail,
    .site-footer__grid {
        grid-template-columns: 1fr;
    }

    .tech-review-showcase__media {
        min-height: 210px;
    }

    .news-item,
    .release-item {
        grid-template-columns: 76px minmax(0, 1fr);
    }

    .release-item time {
        grid-column: 2;
        justify-self: start;
    }

    .topic-panel {
        min-height: auto;
    }

    .topic-panel__item {
        grid-template-columns: 78px minmax(0, 1fr);
    }

    .portal-hero__side {
        padding: 24px 14px;
    }

    .search-form {
        grid-template-columns: 1fr;
    }

    .search-form button {
        width: 100%;
    }

    .auth-shell {
        width: min(100% - 24px, 560px);
        padding: 28px 0;
    }

    .auth-shell::before {
        background:
            linear-gradient(180deg, rgb(5 8 13 / 88%) 0%, rgb(5 8 13 / 70%) 42%, rgb(5 8 13 / 92%) 100%),
            linear-gradient(90deg, rgb(5 8 13 / 80%), rgb(5 8 13 / 60%)),
            url("/images/auth/lumiri-nav-login-bg.webp") center / cover no-repeat;
    }

    .auth-card {
        padding: 28px 20px;
    }

    .auth-back-link,
    .login-form button {
        width: 100%;
    }

    .cookie-consent__banner {
        right: 12px;
        bottom: 12px;
        width: calc(100% - 24px);
        transform: none;
    }

    .cookie-consent__sheet {
        grid-template-columns: 1fr;
    }

    .cookie-consent__actions {
        justify-content: stretch;
    }

    .cookie-consent__actions .button {
        flex: 1 1 100%;
    }

    .cookie-consent__settings {
        left: 12px;
        bottom: 12px;
        max-width: calc(100% - 24px);
    }

    .site-footer__grid {
        gap: 28px;
    }

    .site-footer__section--quick-links {
        grid-column: auto;
    }

    .site-footer__link-list {
        grid-template-columns: 1fr;
    }

    .site-footer__bottom {
        display: grid;
        justify-content: stretch;
    }

    .theme-preview__meta {
        grid-template-columns: 1fr;
    }

    .about-timeline li {
        grid-template-columns: 1fr;
        gap: 8px;
    }

    .redaktion-main,
    .redaktion-sidebar {
        padding: 18px 14px;
    }

    .redaktion-nav,
    .redaktion-list__row {
        grid-template-columns: 1fr;
    }

    .review-platform-picker__grid {
        grid-template-columns: 1fr;
    }

    .redaktion-topbar {
        justify-content: flex-start;
    }
}

@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        scroll-behavior: auto !important;
        transition-duration: 0.01ms !important;
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
    }
}
