/* =============================================================
   Gevinst Guru — style.css
   Koncept C: Varm Redaktionel (warm beige + deep navy)
   Ручной CSS3 на custom properties, mobile-first, без фреймворков.
   Секции: 1 Tokens · 2 Reset/Base · 3 Layout · 4 Typografi
           5 Buttons/Badges · 6 Header/Nav · 7 Footer
           8 Components · 9 Pages · 10 Utilities · 11 Motion/RWD
   ============================================================= */

/* ---------- 0. Fonts (self-hosted, variable, latin) ---------- */
@font-face {
    font-family: "Inter";
    font-style: normal;
    font-weight: 100 900;
    font-display: swap;
    src: url("../fonts/inter.woff2") format("woff2");
}
@font-face {
    font-family: "Sora";
    font-style: normal;
    font-weight: 100 800;
    font-display: swap;
    src: url("../fonts/sora.woff2") format("woff2");
}

/* ---------- 1. Design tokens ---------- */
:root {
    /* Farver — varme flader */
    --bg:          #f6f1e8;
    --bg-soft:     #fbf8f2;
    --surface:     #ffffff;
    --surface-2:   #faf6ef;
    --surface-3:   #f1eadd;

    /* Blæk / tekst */
    --ink:         #1b2230;
    --ink-2:       #474e5e;
    --ink-3:       #585e6c;

    /* Navy-accent */
    --accent:      #16315c;
    --accent-600:  #1d4178;
    --accent-700:  #102745;
    --accent-soft: #e7edf6;
    --on-accent:   #ffffff;

    /* Sekundær: varm guld (doseret) */
    --gold:        #b9842a;
    --gold-ink:    #7a5712;   /* mørk guld til lille tekst på lys baggrund (AA) */
    --gold-soft:   #f0e4c6;

    /* Status */
    --success:     #1f6a45;
    --success-bg:  #e6f1ea;
    --warn:        #b06a16;
    --warn-bg:     #f7ecda;
    --danger:      #a83a46;
    --danger-bg:   #f6e7e8;
    --star:        #d6a429;

    /* Linjer / kanter */
    --border:        rgba(27, 34, 48, .12);
    --border-strong: rgba(27, 34, 48, .20);
    --ring:          rgba(22, 49, 92, .40);

    /* Radius */
    --r-xs: 6px;
    --r-sm: 10px;
    --r:    14px;
    --r-lg: 20px;
    --r-xl: 28px;
    --r-pill: 999px;

    /* Skygger — bløde, lagdelte, varme */
    --sh-1: 0 1px 2px rgba(27,34,48,.04), 0 2px 4px rgba(27,34,48,.04);
    --sh-2: 0 2px 6px rgba(27,34,48,.05), 0 6px 16px -4px rgba(27,34,48,.10);
    --sh-3: 0 4px 12px rgba(27,34,48,.06), 0 16px 36px -8px rgba(16,39,69,.16);
    --sh-4: 0 8px 24px rgba(27,34,48,.08), 0 32px 70px -12px rgba(16,39,69,.28);
    --sh-navy: 0 10px 30px -6px rgba(16,39,69,.45);
    --sh-gold: 0 8px 22px -6px rgba(185,132,42,.45);

    /* Gradienter / effekter */
    --grad-navy:  linear-gradient(145deg, #1d4178 0%, #16315c 52%, #102745 100%);
    --grad-gold:  linear-gradient(135deg, #d9ab3e 0%, #b9842a 100%);
    --grad-sheen: linear-gradient(180deg, rgba(255,255,255,.18), rgba(255,255,255,0) 60%);
    --dot:        radial-gradient(rgba(22,49,92,.16) 1.1px, transparent 1.2px);
    --hairline:   1px solid var(--border);

    /* Typografi */
    --font-display: "Sora", "Segoe UI", system-ui, -apple-system, sans-serif;
    --font-body:    "Inter", "Segoe UI", system-ui, -apple-system, sans-serif;
    --fs-1: clamp(2.2rem, 1.4rem + 3.4vw, 3.6rem);
    --fs-2: clamp(1.7rem, 1.2rem + 2.1vw, 2.6rem);
    --fs-3: clamp(1.35rem, 1.1rem + 1.1vw, 1.85rem);
    --fs-4: clamp(1.15rem, 1.02rem + .5vw, 1.35rem);
    --fs-body: 1.0625rem;   /* 17px */
    --lh:      1.7;

    /* Layout */
    --container: 1180px;
    --container-narrow: 760px;
    --gap: clamp(1rem, .6rem + 1.6vw, 2rem);
    --section-y: clamp(3rem, 2rem + 5vw, 6rem);
    --header-h: 68px;

    --icon-size: 1.2em;

    --ease: cubic-bezier(.22, .61, .36, 1);
}

/* ---------- 2. Reset / base ---------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
    font-family: var(--font-body);
    font-size: var(--fs-body);
    line-height: var(--lh);
    color: var(--ink);
    background: var(--bg);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    overflow-x: hidden;
}

img, svg, video { display: block; max-width: 100%; }
img { height: auto; }
a { color: var(--accent-600); text-decoration: none; }
a:hover { text-decoration: underline; }
button { font: inherit; color: inherit; cursor: pointer; }
ul, ol { list-style: none; padding: 0; }
table { border-collapse: collapse; width: 100%; }
strong { font-weight: 700; }

:focus-visible {
    outline: 3px solid var(--ring);
    outline-offset: 2px;
    border-radius: var(--r-xs);
}

.icon {
    width: var(--icon-size);
    height: var(--icon-size);
    flex: none;
    vertical-align: middle;
    stroke-width: 2;
}

/* ---------- 3. Layout ---------- */
.container {
    width: 100%;
    max-width: var(--container);
    margin-inline: auto;
    padding-inline: clamp(1rem, .5rem + 2.5vw, 2rem);
}
.section { padding-block: var(--section-y); }
.section--tight { padding-block: clamp(2rem, 1.4rem + 3vw, 3.5rem); }
.section--soft { background: var(--bg-soft); }
.section--surface { background: var(--surface); }

.grid { display: grid; gap: var(--gap); }
.grid--cards { grid-template-columns: 1fr; }
.grid--guide4 { grid-template-columns: 1fr; }
@media (min-width: 600px) { .grid--guide4 { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1040px) { .grid--guide4 { grid-template-columns: repeat(4, 1fr); } }

.stack > * + * { margin-top: 1rem; }
.measure { max-width: var(--container-narrow); }

/* ---------- 4. Typografi ---------- */
h1, h2, h3, h4 {
    font-family: var(--font-display);
    line-height: 1.15;
    font-weight: 700;
    letter-spacing: -.015em;
    color: var(--ink);
    text-wrap: balance;
}
h1 { font-size: var(--fs-1); }
h2 { font-size: var(--fs-2); }
h3 { font-size: var(--fs-3); }
h4 { font-size: var(--fs-4); }
p  { color: var(--ink-2); }
.lead { font-size: 1.18rem; color: var(--ink-2); line-height: 1.75; }

.eyebrow {
    display: inline-flex;
    align-items: center;
    gap: .5em;
    padding: .5em .9em .5em .75em;
    border-radius: var(--r-pill);
    background: var(--surface);
    border: 1px solid var(--border);
    box-shadow: var(--sh-1);
    font-family: var(--font-display);
    font-size: .76rem;
    font-weight: 600;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--accent);
}
.eyebrow .icon { color: var(--gold); --icon-size: 1.2em; }
.section-head--center .eyebrow { margin-inline: auto; }
.section-head { max-width: 56ch; margin-bottom: clamp(1.6rem, 1rem + 2vw, 2.6rem); }
.section-head--center { margin-inline: auto; text-align: center; }
.section-head p { margin-top: .7rem; font-size: 1.08rem; }

.prose p { margin-top: 1rem; }
.prose h2 { margin-top: 2.4rem; }
.prose h3 { margin-top: 1.8rem; }
.prose ul { margin-top: 1rem; display: grid; gap: .55rem; }
.prose ul li { position: relative; padding-left: 1.6rem; color: var(--ink-2); }
.prose ul li::before {
    content: ""; position: absolute; left: .3rem; top: .72em;
    width: 7px; height: 7px; border-radius: 50%;
    background: var(--gold);
}
.prose a { text-decoration: underline; text-underline-offset: 2px; }

/* ---------- 5. Buttons / badges ---------- */
.btn {
    --btn-bg: var(--accent);
    --btn-fg: var(--on-accent);
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .5em;
    padding: .85em 1.4em;
    font-family: var(--font-display);
    font-weight: 600;
    font-size: .98rem;
    line-height: 1;
    border: 1px solid transparent;
    border-radius: var(--r-pill);
    background: var(--btn-bg);
    color: var(--btn-fg);
    overflow: hidden;
    isolation: isolate;
    transition: transform .2s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease), border-color .2s var(--ease);
    text-decoration: none;
    white-space: nowrap;
}
.btn > * { position: relative; z-index: 1; }
.btn:hover { text-decoration: none; transform: translateY(-2px); box-shadow: var(--sh-3); }
.btn:active { transform: translateY(0); }
.btn .icon { --icon-size: 1.1em; }
/* Blik-sweep på fyldte knapper */
.btn--primary::before {
    content: ""; position: absolute; inset: 0; z-index: 0;
    background: linear-gradient(100deg, transparent 20%, rgba(255,255,255,.28) 50%, transparent 80%);
    transform: translateX(-120%);
    transition: transform .6s var(--ease);
}
.btn--primary:hover::before { transform: translateX(120%); }
.btn--primary {
    --btn-fg: var(--on-accent);
    background: var(--grad-navy);
    box-shadow: var(--sh-2), inset 0 1px 0 rgba(255,255,255,.14);
}
.btn--primary:hover { box-shadow: var(--sh-navy), inset 0 1px 0 rgba(255,255,255,.18); }
.btn--outline { --btn-bg: var(--surface); --btn-fg: var(--accent); border-color: var(--border-strong); box-shadow: var(--sh-1); }
.btn--outline:hover { --btn-bg: var(--accent-soft); border-color: transparent; box-shadow: var(--sh-2); }
.btn--ghost { --btn-bg: transparent; --btn-fg: var(--ink-2); }
.btn--ghost:hover { --btn-bg: var(--surface-2); box-shadow: none; }
.btn--lg { padding: 1em 1.7em; font-size: 1.05rem; }
.btn--sm { padding: .6em 1em; font-size: .9rem; }
.btn--block { display: flex; width: 100%; }

.badge {
    display: inline-flex; align-items: center; gap: .4em;
    padding: .32em .7em;
    font-size: .78rem; font-weight: 600;
    font-family: var(--font-display);
    border-radius: var(--r-pill);
    background: var(--surface-2);
    color: var(--ink-2);
    border: 1px solid var(--border);
}
.badge .icon { --icon-size: 1.05em; }
.badge--license { background: var(--success-bg); color: var(--success); border-color: transparent; }
.badge--soft { background: var(--gold-soft); color: var(--gold-ink); border-color: transparent; font-size: .72rem; }

/* Stjerner */
.stars { position: relative; display: inline-flex; line-height: 1; }
.stars__base, .stars__fill { display: inline-flex; }
.stars__base .icon { color: #d9cfbe; fill: #d9cfbe; }
.stars__fill { position: absolute; inset: 0; overflow: hidden; white-space: nowrap; }
.stars__fill .icon { color: var(--star); fill: var(--star); }
.stars .icon { --icon-size: 1.05em; stroke-width: 1.5; }

/* Score-ring (kredsløbs-vurdering) — animérbar fyldning via @property */
@property --p { syntax: "<number>"; inherits: false; initial-value: 0; }
.score-ring {
    --p: 90; --t: 5px; --s: 64px;
    position: relative; flex: none;
    width: var(--s); height: var(--s); border-radius: 50%;
    background: conic-gradient(var(--gold) calc(var(--p) * 1%), #e8dcc4 0);
    display: grid; place-items: center; line-height: 1;
    box-shadow: var(--sh-1);
    transition: --p .9s var(--ease);
}
.score-ring::before { content: ""; position: absolute; inset: var(--t); border-radius: 50%; background: var(--surface); box-shadow: inset 0 0 0 1px var(--border); }
.score-ring__val { position: relative; font-family: var(--font-display); font-weight: 800; color: var(--accent); font-size: calc(var(--s) * .30); letter-spacing: -.02em; }
.score-ring__max { position: relative; font-size: calc(var(--s) * .12); color: var(--ink-3); font-weight: 600; margin-top: 1px; }
.score-ring--sm { --s: 52px; --t: 4px; }
.score-ring--lg { --s: 100px; --t: 7px; }
.casino-card--featured .score-ring { background: conic-gradient(var(--gold) calc(var(--p) * 1%), #efe4cb 0); box-shadow: var(--sh-gold); }

.badge--ghost { background: transparent; color: var(--ink-3); border-color: var(--border); }

/* ---------- 6. RG-bar / header / nav ---------- */
.skip-link {
    position: fixed; left: 1rem; top: -100px; z-index: 200;
    background: var(--accent); color: #fff; padding: .7em 1.1em;
    border-radius: var(--r-sm); transition: top .2s var(--ease);
}
.skip-link:focus { top: 1rem; }

.rg-bar {
    background: var(--accent-700);
    color: #dbe4f1;
    font-size: .82rem;
    letter-spacing: .005em;
}
.rg-bar__inner {
    display: flex; align-items: center; gap: .7rem;
    justify-content: center; flex-wrap: wrap;
    padding-block: .5rem; text-align: center;
}
.rg-bar__age {
    background: var(--gold); color: #1a1406;
    font-weight: 700; font-family: var(--font-display);
    padding: .12em .55em; border-radius: var(--r-xs); font-size: .8rem;
}
.rg-bar__text { color: #cdd9ea; }
.rg-bar__text strong { color: #fff; }
.rg-bar a { color: #fff; text-decoration: underline; text-underline-offset: 2px; }
.rg-bar__sep { opacity: .5; }

.site-header {
    position: sticky; top: 0; z-index: 100;
    background: color-mix(in srgb, var(--bg-soft) 88%, transparent);
    backdrop-filter: saturate(140%) blur(10px);
    border-bottom: 1px solid var(--border);
    transition: box-shadow .25s var(--ease), padding .25s var(--ease);
}
.site-header.is-stuck { box-shadow: var(--sh-2); }
.site-header__inner {
    display: flex; align-items: center; gap: 1rem;
    min-height: var(--header-h);
}
.brand { display: inline-flex; align-items: center; gap: .55rem; font-family: var(--font-display); font-weight: 800; font-size: 1.22rem; color: var(--ink); letter-spacing: -.02em; }
.brand:hover { text-decoration: none; }
.brand__mark {
    display: grid; place-items: center;
    width: 2.1rem; height: 2.1rem; border-radius: 10px;
    background: var(--accent); color: #fff;
}
.brand__mark .icon { --icon-size: 1.25rem; }
.brand__accent { color: var(--accent-600); }
.brand--footer { color: #fff; }
.brand--footer .brand__accent { color: var(--gold-soft); }

.main-nav { margin-left: auto; display: none; }
.main-nav__list { display: flex; align-items: center; gap: .2rem; }
.main-nav__link {
    display: inline-block; padding: .55rem .8rem;
    color: var(--ink-2); font-weight: 500; border-radius: var(--r-sm);
    font-size: .96rem; transition: color .15s, background .15s;
}
.main-nav__link:hover { color: var(--accent); background: var(--surface-2); text-decoration: none; }
.main-nav__link.is-active { color: var(--accent); font-weight: 600; }

.header-cta { display: none; }

.nav-toggle {
    margin-left: auto; display: inline-grid; place-items: center;
    width: 2.75rem; height: 2.75rem; border-radius: var(--r-sm);
    background: var(--surface); border: 1px solid var(--border);
}
.nav-toggle .icon { --icon-size: 1.5rem; }
.nav-toggle__close { display: none; }
.nav-toggle[aria-expanded="true"] .nav-toggle__open { display: none; }
.nav-toggle[aria-expanded="true"] .nav-toggle__close { display: block; }

.mobile-nav {
    border-top: 1px solid var(--border);
    background: var(--bg-soft);
    overflow: hidden;
}
.mobile-nav[hidden] { display: none; }
.mobile-nav__list { padding: .6rem clamp(1rem,5vw,2rem) 1.2rem; display: grid; gap: .15rem; }
.mobile-nav__link {
    display: flex; align-items: center; justify-content: space-between;
    padding: .9rem .4rem; color: var(--ink); font-weight: 500;
    border-bottom: 1px solid var(--border);
}
.mobile-nav__link .icon { color: var(--ink-3); --icon-size: 1.1rem; }
.mobile-nav__link.is-active { color: var(--accent); }
.mobile-nav__cta { margin-top: .8rem; }

/* ---------- 7. Footer ---------- */
.site-footer {
    margin-top: var(--section-y);
    background: var(--accent-700);
    color: #c4cfe0;
    padding-block: clamp(2.5rem, 1.5rem + 4vw, 4rem) 1.8rem;
    font-size: .95rem;
}
.site-footer a { color: #e7edf6; }
.site-footer a:hover { color: #fff; }
.site-footer__top {
    display: grid; gap: 2rem;
    grid-template-columns: 1fr;
    padding-bottom: 2rem;
    border-bottom: 1px solid rgba(255,255,255,.12);
}
.site-footer__tagline { color: #aab6ca; margin-top: .8rem; }
.site-footer__legal-entity { margin-top: 1rem; color: #c4cfe0; line-height: 1.6; }
.site-footer__contact { margin-top: 1rem; display: grid; gap: .35rem; }
.site-footer__contact a { display: inline-flex; align-items: center; gap: .5em; }
.site-footer__contact .icon { --icon-size: 1.05em; color: #8fa0bd; }
.site-footer__heading { font-size: .82rem; text-transform: uppercase; letter-spacing: .12em; color: #fff; margin-bottom: 1rem; }
.site-footer__nav ul { display: grid; gap: .4rem; }
.site-footer__nav a { display: inline-block; padding: .2rem 0; }
.site-footer__contact a, .site-footer__rg p a { padding-block: .15rem; }
.site-footer__rg p { margin-bottom: .6rem; }
.site-footer__rg a { display: inline-flex; align-items: center; gap: .5em; }
.site-footer__rg .icon { --icon-size: 1.1em; color: var(--gold-soft); }
.site-footer__age { color: #fff; font-weight: 600; font-family: var(--font-display); margin-bottom: .7rem; }

.site-footer__disclosure {
    display: flex; gap: .8rem; align-items: flex-start;
    padding: 1.2rem; margin-top: 1.8rem;
    background: rgba(255,255,255,.05);
    border: 1px solid rgba(255,255,255,.10);
    border-radius: var(--r);
    font-size: .9rem; color: #d4dded;
}
.site-footer__disclosure .icon { color: var(--gold-soft); flex: none; margin-top: .1em; }
.site-footer__disclosure a { text-decoration: underline; }

.footer-trust { display: flex; align-items: center; gap: 1.2rem 1.8rem; flex-wrap: wrap; margin-top: 1.6rem; padding-top: 1.4rem; border-top: 1px solid rgba(255,255,255,.12); }
.footer-trust__label { font-family: var(--font-display); font-size: .72rem; text-transform: uppercase; letter-spacing: .12em; color: #8fa0bd; }
.footer-trust ul { display: flex; align-items: center; gap: 1.8rem; flex-wrap: wrap; }
.footer-trust__logo { height: 1.45rem; width: auto; opacity: .82; transition: opacity .2s; }
.footer-trust__logo:hover { opacity: 1; }
.footer-trust__logo--invert { filter: brightness(0) invert(1); }

.site-footer__bottom {
    display: flex; flex-wrap: wrap; gap: .5rem 1.5rem; justify-content: space-between;
    margin-top: 1.6rem; font-size: .85rem; color: #aab6c9;
}

/* ---------- 8. Components ---------- */
/* Breadcrumb */
.breadcrumb { background: var(--bg-soft); border-bottom: 1px solid var(--border); }
.breadcrumb__list { display: flex; flex-wrap: wrap; align-items: center; gap: .3rem; padding-block: .8rem; font-size: .86rem; }
.breadcrumb__item { display: inline-flex; align-items: center; gap: .3rem; color: var(--ink-3); }
.breadcrumb__item a { color: var(--ink-2); display: inline-block; padding-block: .2rem; }
.breadcrumb__sep .icon { --icon-size: 1em; color: var(--ink-3); }
.breadcrumb__item [aria-current] { color: var(--ink); font-weight: 600; }

/* Brand-logo chip (rigtige operatørlogoer) */
.brandlogo { display: grid; place-items: center; flex: none; background: #fff; border: 1px solid var(--border); border-radius: 14px; overflow: hidden; box-shadow: var(--sh-1); }
.brandlogo img { max-width: 100%; max-height: 100%; object-fit: contain; }
.brandlogo--mono { background: var(--grad-navy); color: #fff; font-family: var(--font-display); font-weight: 800; box-shadow: var(--sh-navy), inset 0 1px 0 rgba(255,255,255,.2); }
.brandlogo--card { width: 3.4rem; height: 3.4rem; padding: .5rem; }
.brandlogo--hero { width: 4.4rem; height: 4.4rem; padding: .6rem; border-radius: 16px; }
.brandlogo--match { width: 2.6rem; height: 2.6rem; padding: .35rem; border-radius: 10px; }
.brandlogo--table { width: 2.2rem; height: 2.2rem; padding: .25rem; border-radius: 8px; }
.brandlogo--mono.brandlogo--table { font-size: .95rem; }
.brandlogo--mono.brandlogo--card { font-size: 1.4rem; }
.brandlogo--mono.brandlogo--hero { font-size: 1.8rem; }

/* Casino card */
.casino-card {
    position: relative;
    overflow: hidden;
    height: 100%;
    display: flex; flex-direction: column;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--r-lg);
    padding: 1.6rem;
    box-shadow: var(--sh-1);
    transition: transform .22s var(--ease), box-shadow .22s var(--ease), border-color .22s var(--ease);
}
.casino-card:hover { transform: translateY(-5px); box-shadow: var(--sh-3); border-color: var(--border-strong); }
.casino-card--featured { border-color: var(--gold-soft); box-shadow: var(--sh-3); background: linear-gradient(180deg, #fffdf7, var(--surface) 38%); }
.casino-card--featured::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 4px; background: var(--grad-gold); border-radius: var(--r-lg) var(--r-lg) 0 0; }
.casino-card__watermark {
    position: absolute; top: -.6rem; right: .3rem; z-index: 0;
    font-family: var(--font-display); font-weight: 800; font-size: 6.6rem; line-height: 1;
    color: var(--accent); opacity: .055; letter-spacing: -.05em; pointer-events: none;
}
.casino-card--featured .casino-card__watermark { color: var(--gold); opacity: .12; }
.casino-card__ribbon {
    position: absolute; top: 1.1rem; right: -1px; z-index: 3;
    display: inline-flex; align-items: center; gap: .35em;
    background: var(--grad-gold); color: #2c2008;
    font-family: var(--font-display); font-weight: 700; font-size: .73rem;
    padding: .4em .85em; border-radius: var(--r-pill) 0 0 var(--r-pill);
    box-shadow: var(--sh-gold);
}
.casino-card__ribbon .icon { --icon-size: 1.05em; }
.casino-card__head, .casino-card__title, .casino-card__badges, .casino-card__specs, .casino-card__best, .casino-card__actions { position: relative; z-index: 1; }
.casino-card__head { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-bottom: 1rem; min-height: 3.4rem; }
.casino-card__brand { display: inline-flex; align-items: center; height: 3.2rem; max-width: 64%; }
.casino-card__brand img { max-height: 3.2rem; max-width: 100%; width: auto; object-fit: contain; object-position: left center; }
.casino-card__brand-fallback { display: grid; place-items: center; width: 3.2rem; height: 3.2rem; border-radius: 14px; background: var(--grad-navy); color: #fff; font-family: var(--font-display); font-weight: 800; font-size: 1.5rem; }
.casino-card__title { margin-bottom: 1.1rem; }
.casino-card__badges { display: flex; flex-wrap: wrap; gap: .4rem; margin-bottom: 1.2rem; }
.casino-card__name { font-size: 1.28rem; }
.casino-card__tagline { font-size: .88rem; color: var(--ink-3); line-height: 1.4; }
.casino-card__specs {
    display: grid; grid-template-columns: 1fr 1fr; gap: .55rem;
    margin-bottom: 1.2rem;
}
.casino-card__specs li {
    display: flex; align-items: center; gap: .5rem; font-size: .85rem; color: var(--ink-2);
    padding: .6rem .7rem; background: var(--surface-2); border: 1px solid var(--border); border-radius: var(--r-sm);
}
.casino-card__specs .icon { color: var(--accent-600); --icon-size: 1.2em; flex: none; }
.casino-card__best { display: flex; gap: .5rem; font-size: .92rem; color: var(--ink-2); margin-bottom: 1.2rem; }
.casino-card__best .icon { color: var(--gold); flex: none; margin-top: .1em; }
.casino-card__actions { margin-top: auto; display: grid; gap: .6rem; }
.casino-card__visit { text-align: center; font-size: .88rem; color: var(--ink-3); display: inline-flex; gap: .4em; justify-content: center; align-items: center; }
.casino-card__visit .icon { --icon-size: 1em; }

/* Comparison table */
.ctable-wrap { overflow-x: auto; border: 1px solid var(--border); border-radius: var(--r-lg); background: var(--surface); box-shadow: var(--sh-1); }
.ctable { width: 100%; font-size: .85rem; }
.ctable thead th {
    text-align: center; padding: .7rem .4rem; vertical-align: middle;
    background: var(--surface-2); color: var(--ink);
    font-family: var(--font-display); font-size: .77rem; font-weight: 600;
    border-bottom: 2px solid var(--border-strong); white-space: nowrap;
}
.ctable thead th.ctable__name-col { text-align: left; padding-left: 1rem; }
.ctable__sort {
    display: inline-flex; align-items: center; gap: .3em;
    background: none; border: 0; padding: 0; font: inherit; color: inherit; font-weight: 600;
}
.ctable__sort .icon { --icon-size: 1em; color: var(--ink-3); transition: transform .2s; }
.ctable th[aria-sort="ascending"] .icon { transform: rotate(180deg); color: var(--accent); }
.ctable th[aria-sort="descending"] .icon { color: var(--accent); }
.ctable tbody tr { border-bottom: 1px solid var(--border); transition: background .15s; }
.ctable tbody tr:hover { background: var(--surface-2); }
.ctable td, .ctable tbody th { padding: .55rem .4rem; vertical-align: middle; text-align: center; white-space: nowrap; }
.ctable__name { text-align: left; padding-left: 1rem !important; }
.ctable__name a { display: inline-flex; align-items: center; gap: .55rem; font-weight: 600; color: var(--ink); }
.ctable__cta-btn { display: inline-flex; align-items: center; gap: .35em; padding: .42em .75em; border: 1px solid var(--border-strong); border-radius: var(--r-pill); color: var(--accent); font-family: var(--font-display); font-weight: 600; font-size: .8rem; white-space: nowrap; transition: background .15s, border-color .15s, transform .15s; }
.ctable__cta-btn:hover { background: var(--accent-soft); border-color: transparent; text-decoration: none; transform: translateY(-1px); }
.ctable__cta-btn .icon { --icon-size: 1em; }
.ctable__num { font-family: var(--font-display); font-weight: 700; color: var(--accent); }
.ctable__note { margin-top: 1rem; font-size: .85rem; color: var(--ink-3); display: flex; gap: .5rem; }
.ctable__note .icon { flex: none; margin-top: .15em; --icon-size: 1.1em; }
.ctable__stars .icon { --icon-size: .85em; }

/* Leaderboard-varianter */
.score-ring--xs { --s: 44px; --t: 4px; box-shadow: none; }
.score-ring--xs .score-ring__max { display: none; }
.ctable__rating-cell .score-ring { margin-inline: auto; }
.ctable--board tbody tr.is-leader { background: linear-gradient(90deg, rgba(217,171,62,.13), rgba(217,171,62,.04) 55%, transparent); }
.ctable--board tbody tr.is-leader:hover { background: linear-gradient(90deg, rgba(217,171,62,.18), rgba(217,171,62,.05) 55%, transparent); }
.ctable--board tbody tr.is-leader .brandlogo--table { box-shadow: var(--sh-gold); }
.ctable__name-txt { display: inline-flex; flex-direction: column; gap: .15rem; }
.ctable__leader-tag { display: inline-flex; align-items: center; gap: .3em; font-family: var(--font-display); font-size: .66rem; font-weight: 700; color: var(--gold-ink); text-transform: uppercase; letter-spacing: .04em; }
.ctable__leader-tag .icon { --icon-size: 1.15em; }
.ctable td.is-best { color: var(--ink); font-weight: 600; }
.ctable__best-tag { display: inline-flex; align-items: center; gap: .2em; margin-left: .45rem; padding: .12em .5em; border-radius: var(--r-pill); background: var(--success-bg); color: var(--success); font-size: .64rem; font-weight: 700; font-family: var(--font-display); vertical-align: middle; white-space: nowrap; }
.ctable__best-tag .icon { --icon-size: 1em; }

/* Tabs */
.tabs__list { display: flex; flex-wrap: wrap; gap: .4rem; border-bottom: 1px solid var(--border); margin-bottom: 1.4rem; }
.tabs__tab {
    display: inline-flex; align-items: center; gap: .45em;
    padding: .7rem 1rem; background: none; border: 0;
    color: var(--ink-2); font-weight: 600; font-family: var(--font-display); font-size: .95rem;
    border-bottom: 3px solid transparent; margin-bottom: -1px;
    transition: color .15s, border-color .15s;
}
.tabs__tab .icon { --icon-size: 1.15em; color: currentColor; }
.tabs__tab:hover { color: var(--accent); }
.tabs__tab[aria-selected="true"] { color: var(--accent); border-bottom-color: var(--accent); }
.tabs__panel[hidden] { display: none; }
.tabs__panel { animation: fade-in .3s var(--ease); }

/* Definition / check / pay lists */
.def-list { display: grid; gap: .2rem; }
.def-list li { display: grid; grid-template-columns: clamp(9rem, 30%, 13rem) 1fr; gap: 1rem; padding: .85rem 0; border-bottom: 1px solid var(--border); }
.def-list li:last-child { border-bottom: 0; }
.def-list__key { display: inline-flex; align-items: center; gap: .5em; font-weight: 600; color: var(--ink); }
.def-list__key .icon { color: var(--accent-600); --icon-size: 1.15em; }
.def-list li > span:last-child { color: var(--ink-2); }

.check-list { display: grid; gap: .7rem; }
.check-list li { display: flex; gap: .6rem; color: var(--ink-2); }
.check-list .icon { color: var(--success); flex: none; margin-top: .15em; --icon-size: 1.15em; }

.paytable th, .paytable td { padding: .8rem .6rem; text-align: left; border-bottom: 1px solid var(--border); }
.paytable thead th { font-family: var(--font-display); font-size: .85rem; color: var(--ink-3); }
.paytable tbody th { font-weight: 600; color: var(--ink); display: flex; align-items: center; gap: .5rem; flex-wrap: wrap; }

/* Pros / cons */
.pros-cons { display: grid; gap: 1.2rem; }
.pros-cons__col { padding: 1.4rem; border-radius: var(--r); border: 1px solid var(--border); }
.pros-cons__col--pros { background: var(--success-bg); border-color: transparent; }
.pros-cons__col--cons { background: var(--warn-bg); border-color: transparent; }
.pros-cons__title { display: flex; align-items: center; gap: .5rem; font-size: 1.1rem; margin-bottom: 1rem; }
.pros-cons__col--pros .pros-cons__title { color: var(--success); }
.pros-cons__col--cons .pros-cons__title { color: var(--warn); }
.pros-cons ul { display: grid; gap: .65rem; }
.pros-cons li { display: flex; gap: .55rem; color: var(--ink-2); font-size: .96rem; }
.pros-cons li .icon { flex: none; margin-top: .15em; --icon-size: 1.1em; }
.pros-cons__col--pros li .icon { color: var(--success); }
.pros-cons__col--cons li .icon { color: var(--warn); }

/* Callout */
.callout { display: flex; gap: .9rem; padding: 1.3rem 1.4rem; border-radius: var(--r); background: var(--surface-2); border: 1px solid var(--border); }
.callout .icon { flex: none; margin-top: .1em; color: var(--accent-600); }
.callout p { color: var(--ink-2); }
.callout--accent { background: var(--accent-soft); border-color: transparent; }
.callout--accent .icon { color: var(--accent); }
.callout--warn { background: var(--warn-bg); border-color: transparent; }
.callout--warn .icon { color: var(--warn); }

/* License-note (operatør-kontekst for Spillemyndigheden-segl) */
.license-note { display: flex; align-items: center; gap: 1rem; margin-top: 1.2rem; padding: 1rem 1.2rem; background: var(--surface); border: 1px solid var(--border); border-radius: var(--r); box-shadow: var(--sh-1); }
.license-note__seal { width: 3.4rem; height: 3.4rem; flex: none; }
.license-note p { font-size: .92rem; color: var(--ink-2); }
.license-note a { text-decoration: underline; }

/* Affiliate note */
.affiliate-note { display: flex; gap: .6rem; align-items: flex-start; padding: .85rem 1rem; background: var(--surface-2); border: 1px dashed var(--border-strong); border-radius: var(--r-sm); font-size: .86rem; color: var(--ink-3); }
.affiliate-note .icon { flex: none; margin-top: .1em; color: var(--ink-3); --icon-size: 1.15em; }
.affiliate-note--compact { font-size: .82rem; padding: .6rem .8rem; }

/* Accordion */
.accordion { border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; background: var(--surface); }
.accordion__item + .accordion__item { border-top: 1px solid var(--border); }
.accordion__heading { margin: 0; }
.accordion__trigger {
    width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 1rem;
    padding: 1.15rem 1.3rem; background: none; border: 0; text-align: left;
    font-family: var(--font-display); font-weight: 600; font-size: 1.02rem; color: var(--ink);
}
.accordion__trigger:hover { background: var(--surface-2); }
.accordion__icon { display: grid; place-items: center; width: 1.8rem; height: 1.8rem; border-radius: 50%; background: var(--surface-2); transition: transform .25s var(--ease), background .2s; flex: none; }
.accordion__icon .icon { --icon-size: 1.1em; color: var(--accent); }
.accordion__trigger[aria-expanded="true"] .accordion__icon { transform: rotate(180deg); background: var(--accent-soft); }
.accordion__panel[hidden] { display: none; }
.accordion__body { padding: 0 1.3rem 1.3rem; color: var(--ink-2); }
.accordion__body p + p { margin-top: .8rem; }
.accordion__body a { color: var(--accent-600); text-decoration: underline; }

/* Fact card (sidebar) */
.fact-card { position: sticky; top: calc(var(--header-h) + 1rem); background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 1.4rem; box-shadow: var(--sh-1); }
.fact-card__title { font-size: 1.05rem; margin-bottom: 1rem; }
.fact-card__list { display: grid; gap: .1rem; margin-bottom: 1.2rem; }
.fact-card__list li { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: .6rem 0; border-bottom: 1px solid var(--border); font-size: .92rem; }
.fact-card__list li span { display: inline-flex; align-items: center; gap: .5em; color: var(--ink-2); }
.fact-card__list .icon { color: var(--accent-600); --icon-size: 1.1em; }
.fact-card__list strong { color: var(--ink); font-family: var(--font-display); }

/* Visit band */
.visit-band { display: flex; flex-wrap: wrap; gap: 1rem; align-items: center; justify-content: space-between; padding: 1.4rem 1.6rem; background: var(--accent); color: #fff; border-radius: var(--r-lg); margin-block: 1rem; }
.visit-band__name { font-family: var(--font-display); font-weight: 700; font-size: 1.25rem; color: #fff; }
.visit-band__sub { color: #c4d2e8; font-size: .88rem; }
.visit-band .btn--primary { background: #fff; color: var(--accent); }
.visit-band .btn--primary::before { content: none; }
.visit-band .btn--primary:hover { background: var(--gold-soft); }

/* Back to top + cookie reopen */
.back-to-top, .cookie-reopen {
    position: fixed; right: clamp(1rem, 3vw, 2rem); z-index: 90;
    width: 3rem; height: 3rem; border-radius: 50%;
    display: grid; place-items: center;
    background: var(--accent); color: #fff; border: 0; box-shadow: var(--sh-3);
    opacity: 0; visibility: hidden; transform: translateY(12px);
    transition: opacity .25s var(--ease), transform .25s var(--ease), visibility .25s;
}
.back-to-top { bottom: clamp(1rem, 3vw, 2rem); }
.back-to-top.is-visible { opacity: 1; visibility: visible; transform: none; }
.back-to-top:hover { background: var(--accent-600); }
.cookie-reopen { bottom: calc(clamp(1rem,3vw,2rem) + 3.7rem); background: var(--surface); color: var(--accent); border: 1px solid var(--border); }
.cookie-reopen[hidden] { display: none; }
.cookie-reopen:not([hidden]) { opacity: 1; visibility: visible; transform: none; }

/* Cookie consent */
.cookie-consent { position: fixed; inset: auto 0 0 0; z-index: 150; padding: 1rem; display: flex; justify-content: center; }
.cookie-consent[hidden] { display: none; }
.cookie-consent__panel { width: min(640px, 100%); background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); box-shadow: var(--sh-4); padding: clamp(1.2rem, .8rem + 2vw, 1.8rem); animation: slide-up .35s var(--ease); }
.cookie-consent__head { display: flex; align-items: center; gap: .7rem; margin-bottom: .7rem; }
.cookie-consent__icon { display: grid; place-items: center; width: 2.4rem; height: 2.4rem; border-radius: 50%; background: var(--gold-soft); color: var(--gold); flex: none; }
.cookie-consent__title { font-size: 1.2rem; }
.cookie-consent__text { font-size: .92rem; color: var(--ink-2); }
.cookie-consent__text a { text-decoration: underline; }
.cookie-consent__options { display: grid; gap: .5rem; margin: 1.1rem 0; }
.cc-option { display: flex; gap: .7rem; padding: .7rem .85rem; border: 1px solid var(--border); border-radius: var(--r-sm); cursor: pointer; transition: border-color .15s, background .15s; }
.cc-option:hover { border-color: var(--border-strong); background: var(--surface-2); }
.cc-option input { margin-top: .2em; width: 1.1rem; height: 1.1rem; accent-color: var(--accent); flex: none; }
.cc-option--locked { opacity: .75; cursor: not-allowed; }
.cc-option__name { display: block; font-weight: 600; color: var(--ink); font-size: .95rem; }
.cc-option__desc { display: block; font-size: .83rem; color: var(--ink-3); }
.cookie-consent__actions { display: flex; flex-wrap: wrap; gap: .6rem; justify-content: flex-end; }

/* ---------- 9. Pages ---------- */
/* Hero (home, editorial) */
.hero {
    position: relative; overflow: hidden;
    padding-block: clamp(2.4rem, 1.2rem + 5vw, 5rem);
    background:
        radial-gradient(1000px 520px at 90% -14%, var(--accent-soft), transparent 56%),
        radial-gradient(760px 460px at -8% 16%, #f0e6cf, transparent 56%),
        var(--bg);
}
/* Dot-mønster (venstre) + stort kompas-watermark (højre) */
.hero::before {
    content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none;
    background-image: var(--dot); background-size: 24px 24px;
    -webkit-mask-image: radial-gradient(60% 70% at 12% 30%, #000, transparent 70%);
    mask-image: radial-gradient(60% 70% at 12% 30%, #000, transparent 70%);
    opacity: .55;
}
.hero::after {
    content: ""; position: absolute; z-index: 0; pointer-events: none;
    width: min(620px, 56vw); aspect-ratio: 1; right: -12%; top: 46%; transform: translateY(-50%);
    border-radius: 50%;
    background: url("../img/patterns/topo.webp") center / cover no-repeat;
    -webkit-mask-image: radial-gradient(circle, #000 48%, transparent 66%);
    mask-image: radial-gradient(circle, #000 48%, transparent 66%);
    opacity: .14;
}
/* Roteret kant-label (kun bred skærm) */
.hero__rail { display: none; }

.hero__inner { position: relative; z-index: 1; display: grid; gap: clamp(2.2rem, 1rem + 4vw, 3.6rem); align-items: center; }

/* Stempel-eyebrow */
.hero__stamp {
    display: inline-flex; align-items: center; gap: .6em;
    padding: .4em .9em .4em .4em; border-radius: var(--r-pill);
    background: var(--surface); border: 1px solid var(--border); box-shadow: var(--sh-1);
    font-family: var(--font-display); font-size: .76rem; font-weight: 600; letter-spacing: .08em;
    text-transform: uppercase; color: var(--ink-2);
}
.hero__stamp b { display: inline-grid; place-items: center; padding: .25em .6em; border-radius: var(--r-pill); background: var(--grad-navy); color: #fff; letter-spacing: .04em; box-shadow: var(--sh-navy); }

.hero__title { margin-top: 1.2rem; font-size: clamp(2.5rem, 1.3rem + 4.6vw, 4.4rem); line-height: 1.04; letter-spacing: -.03em; }
.hero__title .mark { position: relative; white-space: nowrap; color: var(--accent-600); }
.hero__title .mark::after {
    content: ""; position: absolute; left: -.08em; right: -.08em; bottom: .04em; height: .34em; z-index: -1;
    background: var(--grad-gold); opacity: .55; border-radius: 2px 10px 4px 12px;
    transform: rotate(-.6deg);
}
.hero__lead { margin-top: 1.4rem; max-width: 50ch; font-size: 1.18rem; }
.hero__actions { margin-top: 2rem; display: flex; flex-wrap: wrap; gap: .8rem; }

/* Roster — overlappende monogrammer */
.hero__roster { margin-top: 2.2rem; padding-top: 1.5rem; border-top: var(--hairline); display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; }
.hero__avatars { display: flex; }
.hero__avatars li {
    width: 2.9rem; height: 2.9rem; margin-left: -.75rem; border-radius: 50%;
    display: grid; place-items: center; flex: none; overflow: hidden;
    background: #fff; color: var(--accent); font-family: var(--font-display); font-weight: 800; font-size: 1rem;
    border: 3px solid var(--bg); box-shadow: var(--sh-2);
    padding: .4rem; transition: transform .2s var(--ease), box-shadow .2s var(--ease);
}
.hero__avatars li img { max-width: 100%; max-height: 100%; object-fit: contain; }
.hero__avatars li:first-child { margin-left: 0; }
.hero__avatars li:hover { transform: translateY(-3px); box-shadow: var(--sh-3); z-index: 1; }
.hero__roster p { font-size: .92rem; color: var(--ink-2); max-width: 22ch; }
.hero__roster strong { color: var(--ink); }

/* Panel: quiz + deck + segl */
.hero__panel { position: relative; }
.hero__panel::before {
    content: ""; position: absolute; inset: 0; z-index: 0;
    background: var(--surface-2); border: 1px solid var(--border);
    border-radius: var(--r-xl); transform: rotate(2.4deg) translate(10px, 12px);
    box-shadow: var(--sh-1);
}
.hero__panel .quiz { position: relative; z-index: 1; }
.hero__seal {
    display: none;
    position: absolute; z-index: 2; left: -2.2rem; top: -2.2rem;
    width: clamp(84px, 9vw, 116px); height: auto;
    filter: drop-shadow(var(--sh-3));
}
.hero__seal svg { display: block; animation: seal-spin 40s linear infinite; }
@keyframes seal-spin { to { transform: rotate(360deg); } }

/* Quiz */
.quiz {
    position: relative;
    background:
        radial-gradient(120% 80% at 100% 0%, var(--accent-soft) 0%, transparent 45%),
        var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--r-xl);
    box-shadow: var(--sh-4);
    padding: clamp(1.5rem, 1rem + 2vw, 2.3rem);
    overflow: hidden;
}
.quiz::before {
    content: ""; position: absolute; top: 0; left: 0; right: 0; height: 4px;
    background: var(--grad-gold);
}
.quiz__head { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-bottom: 1.3rem; }
.quiz__kicker { background: none; border: 0; box-shadow: none; padding: 0; color: var(--accent); }
.quiz__steplabel { font-family: var(--font-display); font-size: .76rem; font-weight: 600; color: var(--ink-3); letter-spacing: .04em; }

/* Quiz som visuel rute */
.quiz__route { position: relative; height: 1.9rem; margin: .3rem .1rem 1.5rem; }
.quiz__route-line, .quiz__route-line-fill { position: absolute; left: .8rem; right: .8rem; top: 50%; height: 3px; transform: translateY(-50%); border-radius: 3px; }
.quiz__route-line { background: radial-gradient(circle, var(--border-strong) 38%, transparent 40%) left center / 9px 3px repeat-x; }
.quiz__route-line-fill { right: auto; width: calc(100% - 1.6rem); background: var(--grad-gold); transform-origin: left center; transform: translateY(-50%) scaleX(0); transition: transform .5s var(--ease); }
.quiz__route-nodes { position: absolute; inset: 0; display: flex; justify-content: space-between; align-items: center; }
.quiz__route-node {
    position: relative; z-index: 1; width: 1.6rem; height: 1.6rem; border-radius: 50%;
    display: grid; place-items: center; background: var(--surface);
    border: 2px solid var(--border-strong); color: var(--ink-3);
    font-family: var(--font-display); font-weight: 700; font-size: .72rem;
    transition: border-color .3s var(--ease), background .3s var(--ease), box-shadow .3s var(--ease), color .3s var(--ease);
}
.quiz__route-node .icon { --icon-size: .9rem; }
.quiz__route-node .qn-active, .quiz__route-node .qn-done { display: none; }
.quiz__route-node.is-active { border-color: var(--accent); color: var(--accent); background: var(--surface); box-shadow: 0 0 0 5px var(--accent-soft); }
.quiz__route-node.is-active .qn-num { display: none; }
.quiz__route-node.is-active .qn-active { display: grid; animation: marker-bob 1.4s var(--ease) infinite; }
.quiz__route-node.is-done { border-color: var(--gold); background: var(--grad-gold); color: #2a1f06; box-shadow: none; }
.quiz__route-node.is-done .qn-num, .quiz__route-node.is-done .qn-active { display: none; }
.quiz__route-node.is-done .qn-done { display: grid; }
@keyframes marker-bob { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-2px) rotate(-8deg); } }
.quiz__step { display: none; animation: fade-in .3s var(--ease); }
.quiz__step.is-active { display: block; }
.quiz__q { font-size: 1.3rem; margin-bottom: 1.1rem; }
.quiz__options { display: grid; gap: .7rem; }
.quiz__option { display: flex; align-items: center; gap: .8rem; width: 100%; text-align: left; padding: 1rem 1.1rem; background: var(--surface-2); border: 1px solid var(--border); border-radius: var(--r); font-weight: 500; color: var(--ink); transition: border-color .15s, background .15s, transform .15s; }
.quiz__option:hover { border-color: var(--accent); background: var(--accent-soft); transform: translateX(3px); }
.quiz__option .icon { color: var(--accent-600); }
.quiz__nav { margin-top: 1.2rem; display: flex; justify-content: space-between; }
.quiz__result { display: none; text-align: center; animation: fade-in .35s var(--ease); }
.quiz__result.is-active { display: block; }
.quiz__result-label { display: inline-flex; align-items: center; gap: .5em; color: var(--success); font-weight: 600; font-family: var(--font-display); margin-bottom: .6rem; }
.quiz__result-name { font-size: 2rem; font-family: var(--font-display); color: var(--accent); margin-bottom: .3rem; }

/* Section heading helper with icon chip */
.icon-chip {
    position: relative; display: inline-grid; place-items: center;
    width: 3.1rem; height: 3.1rem; border-radius: 15px; margin-bottom: 1.1rem;
    background: var(--grad-navy); color: #fff;
    box-shadow: var(--sh-navy), inset 0 1px 0 rgba(255,255,255,.20);
}
.icon-chip::after { content: ""; position: absolute; inset: 0; border-radius: inherit; background: var(--grad-sheen); mix-blend-mode: screen; }
.icon-chip .icon { --icon-size: 1.5rem; position: relative; z-index: 1; }
.icon-chip--gold { background: var(--grad-gold); color: #fff; box-shadow: var(--sh-gold), inset 0 1px 0 rgba(255,255,255,.28); }

/* Feature / value grid */
.feature { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 1.7rem; box-shadow: var(--sh-1); transition: transform .22s var(--ease), box-shadow .22s var(--ease), border-color .22s var(--ease); }
.feature:hover { transform: translateY(-4px); box-shadow: var(--sh-3); border-color: var(--border-strong); }
.feature h3 { font-size: 1.18rem; margin-bottom: .5rem; }
.feature p { font-size: .96rem; }

/* Guide / link cards */
.linkcard { display: flex; flex-direction: column; gap: .6rem; background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 1.5rem; box-shadow: var(--sh-1); transition: transform .2s var(--ease), box-shadow .2s var(--ease), border-color .2s; }
.linkcard:hover { transform: translateY(-3px); box-shadow: var(--sh-3); border-color: var(--border-strong); text-decoration: none; }
.linkcard__meta { display: flex; flex-wrap: wrap; align-items: center; gap: .4rem .9rem; font-size: .78rem; color: var(--ink-3); margin-top: auto; padding-top: .9rem; border-top: 1px solid var(--border); }
.linkcard__meta span { display: inline-flex; align-items: center; gap: .4em; white-space: nowrap; }
.linkcard__meta .icon { --icon-size: 1.05em; flex: none; }
.linkcard h3 { font-size: 1.2rem; }
.linkcard p { font-size: .95rem; }
.linkcard__more { display: inline-flex; align-items: center; gap: .4em; color: var(--accent-600); font-weight: 600; font-family: var(--font-display); font-size: .92rem; }
.linkcard:hover .linkcard__more .icon { transform: translateX(3px); }
.linkcard__more .icon { transition: transform .2s var(--ease); }

/* Article (guides) */
.article-hero { position: relative; overflow: hidden; background:
    radial-gradient(800px 320px at 90% -30%, var(--accent-soft), transparent 60%),
    var(--bg-soft); border-bottom: 1px solid var(--border); padding-block: clamp(2.2rem,1.4rem+3vw,3.6rem); }
.article-hero > .container { position: relative; z-index: 1; }
.article-hero h1 { font-size: clamp(2rem, 1.4rem + 2.6vw, 3rem); letter-spacing: -.02em; }
.article-hero__meta { display: flex; flex-wrap: wrap; gap: .8rem 1.4rem; margin-top: 1rem; font-size: .88rem; color: var(--ink-3); }
.article-hero__meta span { display: inline-flex; align-items: center; gap: .4em; }
.article-layout { display: grid; gap: 2.5rem; padding-block: var(--section-y); }
.toc { background: var(--surface-2); border: 1px solid var(--border); border-radius: var(--r); padding: 1.2rem 1.4rem; }
.toc__title { font-family: var(--font-display); font-size: .82rem; text-transform: uppercase; letter-spacing: .1em; color: var(--ink-3); margin-bottom: .8rem; }
.toc ol { display: grid; gap: .5rem; counter-reset: toc; }
.toc li { counter-increment: toc; }
.toc a { display: flex; gap: .6rem; color: var(--ink-2); font-size: .94rem; }
.toc a::before { content: counter(toc); display: grid; place-items: center; width: 1.5rem; height: 1.5rem; border-radius: 50%; background: var(--surface); border: 1px solid var(--border); font-size: .78rem; font-weight: 700; color: var(--accent); flex: none; }
.toc a:hover { color: var(--accent); text-decoration: none; }

/* Glossary */
.glossary-controls { display: flex; flex-wrap: wrap; gap: 1rem; align-items: center; margin-bottom: 2rem; }
.search-field { position: relative; flex: 1; min-width: 220px; }
.search-field .icon { position: absolute; left: 1rem; top: 50%; transform: translateY(-50%); color: var(--ink-3); }
.search-field input { width: 100%; padding: .85rem 1rem .85rem 2.8rem; border: 1px solid var(--border-strong); border-radius: var(--r-pill); background: var(--surface); font: inherit; color: var(--ink); }
.search-field input:focus-visible { outline: 3px solid var(--ring); border-color: var(--accent); }
.glossary-list { display: grid; gap: 1rem; }
.glossary-item { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r); padding: 1.3rem 1.5rem; box-shadow: var(--sh-1); }
.glossary-item h3 { font-size: 1.15rem; margin-bottom: .4rem; display: flex; align-items: center; gap: .6rem; }
.glossary-item__letter { display: grid; place-items: center; width: 2rem; height: 2rem; border-radius: 8px; background: var(--accent-soft); color: var(--accent); font-family: var(--font-display); font-weight: 700; font-size: .95rem; flex: none; }
.glossary-item p { font-size: .96rem; }
.glossary-item p a { text-decoration: underline; }
.glossary-empty { text-align: center; color: var(--ink-3); padding: 2rem; display: none; }
.glossary-item[hidden] { display: none; }

/* Filters (catalog) */
.filterbar { display: flex; flex-wrap: wrap; gap: .6rem; align-items: center; margin-bottom: 2rem; padding: 1rem 1.2rem; background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); box-shadow: var(--sh-1); }
.filterbar__label { display: inline-flex; align-items: center; gap: .45em; font-weight: 600; font-family: var(--font-display); color: var(--ink); font-size: .92rem; margin-right: .3rem; }
.filterbar__label .icon { color: var(--accent-600); }
.chip { display: inline-flex; align-items: center; gap: .4em; padding: .5em .95em; border-radius: var(--r-pill); background: var(--surface-2); border: 1px solid var(--border); color: var(--ink-2); font-size: .88rem; font-weight: 500; transition: all .15s; }
.chip:hover { border-color: var(--accent); color: var(--accent); }
.chip.is-active { background: var(--accent); color: #fff; border-color: var(--accent); }
.catalog-count { margin: 1.4rem 0; color: var(--ink-3); font-size: .92rem; }
.catalog-empty { display: none; text-align: center; padding: 3rem 1rem; color: var(--ink-3); }

/* Page hero (generic) */
.page-hero { position: relative; overflow: hidden; background:
    radial-gradient(900px 380px at 85% -20%, var(--accent-soft), transparent 60%),
    var(--bg-soft); border-bottom: 1px solid var(--border); padding-block: clamp(2.6rem, 1.6rem + 4.5vw, 4.4rem); }
.page-hero::before {
    content: ""; position: absolute; inset: 0; pointer-events: none;
    background-image: var(--dot); background-size: 22px 22px;
    -webkit-mask-image: radial-gradient(60% 70% at 88% 10%, #000, transparent 72%);
    mask-image: radial-gradient(60% 70% at 88% 10%, #000, transparent 72%);
    opacity: .6;
}
.page-hero__inner { position: relative; z-index: 1; max-width: 64ch; }
.page-hero h1 { font-size: clamp(2.1rem, 1.4rem + 3vw, 3.2rem); letter-spacing: -.02em; margin-top: .9rem; }
.page-hero p { margin-top: 1rem; font-size: 1.12rem; }

/* Firma-illustrationer */
.illu { display: block; line-height: 0; }
.illu svg { width: 100%; height: auto; display: block; }
.illu-img { width: 100%; height: auto; display: block; border-radius: var(--r-lg); }
.page-hero__art .illu-img { box-shadow: 0 16px 36px -8px rgba(16,39,69,.20); }

/* Split-hero med illustration */
.page-hero--split .page-hero__inner { max-width: var(--container); display: grid; gap: clamp(1.5rem, 1rem + 3vw, 3rem); align-items: center; }
.page-hero--split .page-hero__text { max-width: 60ch; }
.page-hero__art { width: 100%; max-width: 440px; justify-self: start; }
.page-hero__art .illu svg { filter: drop-shadow(0 14px 32px rgba(16,39,69,.13)); }
@media (min-width: 860px) {
    .page-hero--split .page-hero__inner { grid-template-columns: 1.1fr .9fr; }
    .page-hero__art { justify-self: end; }
}

/* Compare-hero + legende */
.compare-hero { position: relative; overflow: hidden; border-bottom: 1px solid var(--border);
    background: radial-gradient(900px 360px at 88% -30%, var(--accent-soft), transparent 60%), var(--bg-soft);
    padding-block: clamp(2.4rem, 1.6rem + 4vw, 4rem); }
.compare-hero::before {
    content: ""; position: absolute; inset: 0; pointer-events: none;
    background-image: var(--dot); background-size: 24px 24px;
    -webkit-mask-image: radial-gradient(55% 70% at 90% 8%, #000, transparent 72%);
    mask-image: radial-gradient(55% 70% at 90% 8%, #000, transparent 72%);
    opacity: .55;
}
.compare-hero__inner { position: relative; z-index: 1; }
.compare-hero__text { max-width: 60ch; }
.compare-hero h1 { font-size: clamp(2.1rem, 1.4rem + 3vw, 3.3rem); letter-spacing: -.025em; margin-top: 1rem; }
.compare-hero p { margin-top: 1rem; font-size: 1.12rem; }
.hero__stamp b:only-child, .compare-hero .hero__stamp b { letter-spacing: .06em; }
.legend { margin-top: 1.6rem; display: flex; flex-wrap: wrap; gap: .7rem 1.5rem; }
.legend li { display: inline-flex; align-items: center; gap: .55em; font-size: .88rem; color: var(--ink-2); }
.legend__ring { width: 1.15rem; height: 1.15rem; border-radius: 50%; flex: none; background: conic-gradient(var(--gold) 82%, #e8dcc4 0); box-shadow: inset 0 0 0 3px var(--surface), inset 0 0 0 4px var(--border); }
.legend__chip { display: inline-grid; place-items: center; width: 1.45rem; height: 1.45rem; border-radius: 50%; flex: none; }
.legend__chip .icon { --icon-size: .95em; }
.legend__chip--best { background: var(--success-bg); color: var(--success); }
.legend__chip--leader { background: var(--gold-soft); color: var(--gold); }

/* Match-cards */
.matchgrid { display: grid; gap: 1rem; grid-template-columns: 1fr; }
.matchcard { position: relative; display: grid; gap: .7rem; align-content: start; padding: 1.5rem; background: var(--surface); border: 1px solid var(--border); border-left: 4px solid var(--gold); border-radius: 0 var(--r-lg) var(--r-lg) 0; box-shadow: var(--sh-1); transition: transform .2s var(--ease), box-shadow .2s var(--ease); }
.matchcard:hover { transform: translateY(-3px); box-shadow: var(--sh-3); text-decoration: none; }
.matchcard__head { display: flex; align-items: center; gap: .7rem; }
.matchcard__logo { width: 2.5rem; height: 2.5rem; border-radius: 11px; display: grid; place-items: center; flex: none; background: var(--grad-navy); color: #fff; font-family: var(--font-display); font-weight: 800; box-shadow: var(--sh-1), inset 0 1px 0 rgba(255,255,255,.2); }
.matchcard__name { font-family: var(--font-display); font-weight: 700; font-size: 1.15rem; color: var(--ink); margin-right: auto; }
.matchcard__q { color: var(--ink); font-size: .96rem; }
.matchcard__q .icon { --icon-size: 1.05em; color: var(--gold); vertical-align: -2px; margin-right: .2em; }
.matchcard__q strong { color: var(--accent-600); }
.matchcard__why { font-size: .92rem; color: var(--ink-2); }
.matchcard__more { display: inline-flex; align-items: center; gap: .4em; font-family: var(--font-display); font-weight: 600; font-size: .9rem; color: var(--accent-600); }
.matchcard__more .icon { transition: transform .2s var(--ease); }
.matchcard:hover .matchcard__more .icon { transform: translateX(3px); }
@media (min-width: 640px) { .matchgrid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 980px) { .matchgrid { grid-template-columns: repeat(3, 1fr); } }

/* RG resource cards */
.resource { display: flex; gap: 1rem; padding: 1.4rem; background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); box-shadow: var(--sh-1); }
.resource__icon { display: grid; place-items: center; width: 3rem; height: 3rem; border-radius: 14px; background: var(--accent-soft); color: var(--accent); flex: none; }
.resource__icon .icon { --icon-size: 1.5rem; }
.resource h3 { font-size: 1.15rem; margin-bottom: .3rem; }
.rg-logo { height: 1.7rem; width: auto; margin-bottom: .7rem; display: block; }
.resource p { font-size: .94rem; margin-bottom: .6rem; }
.resource a.btn { margin-top: .3rem; }

/* Contact form (imitation) */
.form { display: grid; gap: 1.1rem; }
.field { display: grid; gap: .4rem; }
.field label { font-weight: 600; font-size: .92rem; color: var(--ink); }
.field input, .field textarea { width: 100%; padding: .8rem 1rem; border: 1px solid var(--border-strong); border-radius: var(--r-sm); background: var(--surface); font: inherit; color: var(--ink); }
.field input:focus-visible, .field textarea:focus-visible { outline: 3px solid var(--ring); border-color: var(--accent); }
.field textarea { resize: vertical; min-height: 130px; }
.field__error { color: var(--danger); font-size: .84rem; display: none; }
.field.has-error input, .field.has-error textarea { border-color: var(--danger); }
.field.has-error .field__error { display: block; }
.form__success { display: none; gap: .7rem; align-items: center; padding: 1rem 1.2rem; background: var(--success-bg); color: var(--success); border-radius: var(--r); font-weight: 500; }
.form__success.is-visible { display: flex; }
.form__success .icon { color: var(--success); }

/* Methodology steps */
.steps { display: grid; gap: 1.2rem; counter-reset: step; }
.step { display: flex; gap: 1.1rem; padding: 1.3rem 1.4rem; background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); box-shadow: var(--sh-1); }
.step::before { counter-increment: step; content: counter(step); display: grid; place-items: center; width: 2.6rem; height: 2.6rem; border-radius: 50%; background: var(--accent); color: #fff; font-family: var(--font-display); font-weight: 700; flex: none; }
.step h3 { font-size: 1.1rem; margin-bottom: .3rem; }
.step p { font-size: .94rem; }

/* CTA band */
.cta-band { position: relative; overflow: hidden; background: var(--grad-navy); color: #fff; border-radius: var(--r-xl); padding: clamp(2.2rem, 1.4rem + 3.5vw, 3.8rem); text-align: center; box-shadow: var(--sh-4); }
.cta-band::before {
    content: ""; position: absolute; inset: 0; pointer-events: none;
    background-image: radial-gradient(rgba(255,255,255,.10) 1px, transparent 1.4px);
    background-size: 22px 22px;
    -webkit-mask-image: radial-gradient(80% 80% at 50% 0%, #000, transparent 70%);
    mask-image: radial-gradient(80% 80% at 50% 0%, #000, transparent 70%);
}
.cta-band::after {
    content: ""; position: absolute; width: 320px; height: 320px; right: -80px; bottom: -140px;
    background: radial-gradient(circle, rgba(217,171,62,.22), transparent 65%); pointer-events: none;
}
.cta-band > * { position: relative; z-index: 1; }
.cta-band h2 { color: #fff; }
.cta-band p { color: #e2eaf6; max-width: 50ch; margin: 1rem auto 1.8rem; }
.cta-band .btn--primary { background: #fff; color: var(--accent); box-shadow: var(--sh-2); }
.cta-band .btn--primary::before { content: none; }
.cta-band .btn--primary:hover { background: var(--gold-soft); box-shadow: var(--sh-3); }
.cta-band .btn--outline { --btn-bg: transparent; --btn-fg: #fff; border-color: rgba(255,255,255,.55); box-shadow: none; }
.cta-band .btn--outline:hover { --btn-bg: rgba(255,255,255,.15); border-color: rgba(255,255,255,.8); }
.cta-band__actions { display: flex; flex-wrap: wrap; gap: .8rem; justify-content: center; }

/* Detail page layout */
.casino-hero { position: relative; overflow: hidden; background:
    radial-gradient(900px 360px at 90% -30%, var(--accent-soft), transparent 60%),
    var(--bg-soft); border-bottom: 1px solid var(--border); padding-block: clamp(2.2rem,1.4rem+3vw,3.2rem); }
.casino-hero::before {
    content: ""; position: absolute; inset: 0; pointer-events: none;
    background-image: var(--dot); background-size: 22px 22px;
    -webkit-mask-image: radial-gradient(55% 80% at 92% 0%, #000, transparent 70%);
    mask-image: radial-gradient(55% 80% at 92% 0%, #000, transparent 70%);
    opacity: .55;
}
.casino-hero__inner { position: relative; z-index: 1; display: grid; gap: 1.6rem; }
.casino-hero__id { display: flex; align-items: center; gap: 1rem; }
.casino-hero__name { font-size: var(--fs-2); }
.casino-hero__tagline { color: var(--ink-2); font-size: 1.05rem; }
.casino-hero__meta { display: flex; flex-wrap: wrap; gap: .7rem 1.2rem; align-items: center; font-size: .9rem; color: var(--ink-2); }
.casino-hero__meta > span { display: inline-flex; align-items: center; gap: .45em; }
.casino-hero__meta .icon { color: var(--ink-3); --icon-size: 1.1em; }
.casino-hero__rating { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); box-shadow: var(--sh-2); padding: 1.4rem; text-align: center; display: grid; gap: .7rem; justify-items: center; }
.rating-badge { display: flex; align-items: baseline; gap: .2rem; }
.rating-badge__score { font-family: var(--font-display); font-weight: 800; font-size: 2.6rem; color: var(--accent); line-height: 1; }
.rating-badge__max { color: var(--ink-3); font-weight: 600; }
.rating-badge__label { font-size: .82rem; color: var(--ink-3); }

.casino-detail__body { display: grid; gap: 2rem; padding-block: var(--section-y); }
.casino-section { margin-bottom: 2.4rem; }
.casino-section > h2 { margin-bottom: 1rem; }
.casino-section__hint { margin-top: 1rem; display: flex; gap: .5rem; align-items: flex-start; color: var(--ink-2); font-size: .94rem; }
.casino-section__hint .icon { flex: none; margin-top: .15em; color: var(--accent-600); }
.casino-section__hint--rg { padding: 1rem 1.2rem; background: var(--surface-2); border-radius: var(--r-sm); }
.casino-section__hint--rg .icon { color: var(--success); }
.casino-section__hint a { text-decoration: underline; }
.casino-detail__related { padding-bottom: var(--section-y); }
.casino-detail__related h2 { margin-bottom: 1.4rem; }

/* ---------- 10. Utilities ---------- */
.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; }
.text-center { text-align: center; }
.mt-0 { margin-top: 0; }
.flow > * + * { margin-top: 1.1rem; }
.divider { height: 1px; background: var(--border); border: 0; margin-block: var(--section-y); }
.tag-list { display: flex; flex-wrap: wrap; gap: .4rem; }

/* ---------- 11. Motion + responsive ---------- */
@keyframes fade-in { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }
@keyframes slide-up { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: none; } }

/* Reveal kun aktivt når JS er til (progressiv forbedring; synligt uden JS) */
.js [data-reveal] { opacity: 0; transform: translateY(20px); transition: opacity .6s var(--ease), transform .6s var(--ease); }
.js [data-reveal].is-visible { opacity: 1; transform: none; }
.js [data-reveal][data-reveal-delay="1"] { transition-delay: .08s; }
.js [data-reveal][data-reveal-delay="2"] { transition-delay: .16s; }
.js [data-reveal][data-reveal-delay="3"] { transition-delay: .24s; }

/* Marquee (trust strip) */
.marquee { position: relative; overflow: hidden; background: var(--grad-navy); padding-block: 1.05rem; box-shadow: var(--sh-2); }
.marquee::before, .marquee::after { content: ""; position: absolute; top: 0; bottom: 0; width: 70px; z-index: 1; pointer-events: none; }
.marquee::before { left: 0; background: linear-gradient(90deg, var(--accent-700), transparent); }
.marquee::after { right: 0; background: linear-gradient(270deg, var(--accent-700), transparent); }
.marquee__track { display: flex; gap: 3rem; width: max-content; animation: marquee 36s linear infinite; }
.marquee__item { display: inline-flex; align-items: center; gap: .55em; color: #d3deee; font-size: .9rem; font-weight: 500; white-space: nowrap; }
.marquee__item .icon { color: var(--gold-soft); --icon-size: 1.15em; }
@keyframes marquee { to { transform: translateX(-50%); } }

/* Tablet */
@media (min-width: 640px) {
    .grid--cards { grid-template-columns: repeat(2, 1fr); }
    .pros-cons { grid-template-columns: 1fr 1fr; }
    .casino-hero__inner { grid-template-columns: 1fr; }
    .cookie-consent__actions { justify-content: flex-end; }
}

@media (min-width: 860px) {
    .site-footer__top { grid-template-columns: 1.6fr 1fr 1fr 1.2fr; gap: 2.5rem; }
    .article-layout { grid-template-columns: 260px 1fr; align-items: start; }
    .toc { position: sticky; top: calc(var(--header-h) + 1rem); }
}

/* Desktop */
@media (min-width: 980px) {
    .main-nav { display: block; }
    .header-cta { display: inline-flex; }
    .nav-toggle { display: none; }
    .grid--cards { grid-template-columns: repeat(3, 1fr); }
    .grid--2 { grid-template-columns: repeat(2, 1fr); }
    .hero__inner { grid-template-columns: 1.08fr .92fr; }
    .hero__seal { display: block; }
    .hero__rail {
        display: block; position: absolute; z-index: 1; left: max(.5rem, calc((100vw - var(--container)) / 2 - 1.2rem)); top: 50%;
        transform: rotate(180deg) translateY(-50%); transform-origin: center;
        writing-mode: vertical-rl; font-family: var(--font-display); font-size: .72rem; font-weight: 600;
        letter-spacing: .35em; text-transform: uppercase; color: var(--ink-3);
    }
    .casino-hero__inner { grid-template-columns: 1fr 280px; align-items: center; }
    .casino-detail__body { grid-template-columns: 1fr 320px; align-items: start; }
}

@media (min-width: 1100px) {
    .grid--4 { grid-template-columns: repeat(4, 1fr); }
}

/* Mobile comparison table → stacked cards */
@media (max-width: 720px) {
    .ctable-wrap { overflow: visible; border: 0; background: none; box-shadow: none; }
    .ctable { min-width: 0; }
    .ctable thead { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); }
    .ctable tbody tr { display: grid; grid-template-columns: 1fr 1fr; gap: .4rem .8rem; background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 1.1rem 1.2rem; margin-bottom: 1rem; box-shadow: var(--sh-1); }
    .ctable tbody tr:hover { background: var(--surface); }
    .ctable__name { grid-column: 1 / -1; padding: 0 0 .6rem; border-bottom: 1px solid var(--border); }
    .ctable td { padding: .15rem 0; display: flex; flex-direction: column; gap: .1rem; font-size: .9rem; }
    .ctable td::before { content: attr(data-label); font-size: .72rem; text-transform: uppercase; letter-spacing: .05em; color: var(--ink-3); font-weight: 600; }
    .ctable__cta { grid-column: 1 / -1; }
    .ctable__cta::before { display: none; }
    .ctable__cta .btn { width: 100%; margin-top: .4rem; }
}

@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; scroll-behavior: auto !important; }
    [data-reveal] { opacity: 1; transform: none; }
    .marquee__track { animation: none; }
}
