:root {
    --bg: #f5f7fb; /* lys baggrund */
    --card: #ffffff;
    --ink: #101828;
    --muted: #5b6675;
    --primary: #0ea5e9; /* skyblue */
    --primary-700: #0284c7;
    --accent: #0f766e; /* teal */
    --ring: rgba(14, 165, 233, .25);
}

html, body {
    background: var(--bg);
    color: var(--ink);
    font-family: Manrope, Inter, system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Noto Sans, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
}

/* ---------------- Header ---------------- */
.site-header {
    position: sticky;
    top: 0;
    z-index: 1030;
    backdrop-filter: saturate(180%) blur(8px);
    background: rgba(255, 255, 255, .75);
    border-bottom: 1px solid rgba(2, 132, 199, .08);
}

.brand-mark {
    display: flex;
    align-items: center;
    gap: .6rem;
    text-decoration: none;
    color: var(--ink);
    font-weight: 800;
    letter-spacing: .2px
}

.brand-logo {
    width: 36px;
    height: 36px;
    border-radius: 10px;
    background: conic-gradient(from 210deg, #38bdf8, #99f6e4, #e0f2fe, #38bdf8);
    position: relative;
    box-shadow: inset 0 0 0 4px #fff;
}

.brand-logo::after {
    content: "";
    position: absolute;
    inset: 6px;
    border-radius: 8px;
    background: radial-gradient(120px 60px at 30% 30%, rgba(255, 255, 255, .85), transparent 55%),
    radial-gradient(120px 80px at 70% 70%, rgba(255, 255, 255, .35), transparent 60%),
    linear-gradient(135deg, rgba(2, 132, 199, .35), rgba(16, 185, 129, .35));
    box-shadow: 0 2px 10px rgba(2, 132, 199, .15) inset;
}

.nav-link {
    font-weight: 600;
    color: var(--muted);
}

.nav-link:hover, .nav-link:focus {
    color: var(--primary-700);
}

.btn-cta {
    --bs-btn-padding-y: .6rem;
    --bs-btn-padding-x: 1rem;
    --bs-btn-font-weight: 800;
    border-radius: 12px;
    box-shadow: 0 6px 18px rgba(14, 165, 233, .25), inset 0 0 0 1px rgba(255, 255, 255, .3);
}

/* badge row under header */
.subbar {
    background: linear-gradient(90deg, rgba(2, 132, 199, .08), rgba(16, 185, 129, .08));
    border-bottom: 1px solid rgba(2, 132, 199, .08);
    font-size: .9rem
}

/* ---------------- Hero ---------------- */
.hero {
    position: relative;
    overflow: clip;
}

.hero-gradient {
    position: absolute;
    inset: 0;
    background: radial-gradient(90rem 40rem at -10% -10%, rgba(2, 132, 199, .12), transparent 55%),
    radial-gradient(70rem 35rem at 110% 10%, rgba(16, 185, 129, .10), transparent 55%),
    radial-gradient(60rem 28rem at 50% 110%, rgba(14, 165, 233, .10), transparent 60%),
    linear-gradient(180deg, #ffffff, #f7fbff 60%, #f0fbf8 100%);
}

/* subtle pattern of chips/cards using CSS masks */
.hero-pattern {
    position: absolute;
    inset: -40% -10% -20% -10%;
    background: repeating-linear-gradient(60deg, rgba(2, 132, 199, .05) 0 14px, rgba(2, 132, 199, .02) 14px 28px),
    radial-gradient(18px 18px at 14% 22%, rgba(2, 132, 199, .08) 30%, transparent 31%) repeat;
    mask-image: radial-gradient(100% 65% at 50% 40%, #000 55%, transparent 75%);
}

.hero .container {
    position: relative;
    z-index: 2;
}

.eyebrow {
    color: var(--accent);
    font-weight: 800;
    letter-spacing: .12em;
    text-transform: uppercase;
    font-size: .85rem
}

.hero-title {
    font-weight: 800;
    line-height: 1.1;
}

.hero-lead {
    color: var(--muted);
    font-size: 1.1rem;
}

.glass {
    background: rgba(255, 255, 255, .7);
    border: 1px solid rgba(2, 132, 199, .12);
    box-shadow: 0 10px 30px rgba(2, 132, 199, .10);
    border-radius: 18px;
    backdrop-filter: blur(6px);
}

.trust-list img {
    height: 28px;
    opacity: .9;
}

.trust-list .divider {
    width: 1px;
    height: 26px;
    background: rgba(2, 132, 199, .18);
}

.age-pill {
    font-weight: 800;
    letter-spacing: .06em;
}

@media (max-width: 991.98px) {
    .hero-title {
        font-size: clamp(2rem, 5vw, 3rem);
    }
}

.casino-section {
    scroll-margin-top: 84px;
}

.casino-card {
    background: var(--card);
    border: 1px solid rgba(2, 132, 199, .10);
    border-radius: 18px;
    box-shadow: 0 10px 24px rgba(2, 132, 199, .06);
}

.casino-card .brand-box {
    flex-wrap: wrap;
    background: linear-gradient(135deg, rgba(2, 132, 199, .08), rgba(16, 185, 129, .08));
    border: 1px solid rgba(2, 132, 199, .12);
    border-radius: 14px;
}

.brand-mark-lg {
    font-weight: 900;
    letter-spacing: .2px;
    font-size: 1.4rem;
}

.feature {
    display: flex;
    gap: .6rem;
    align-items: flex-start;
}

.feature .check {
    color: var(--accent);
}

.stars svg {
    width: 20px;
    height: 20px;
    color: #fbbf24;
}

.label {
    font-size: .78rem;
    font-weight: 700;
    padding: .3rem .55rem;
    border-radius: 999px;
    background: rgba(2, 132, 199, .08);
    color: var(--primary-700);
}

.cta-slot .btn {
    min-width: 160px;
    border-radius: 12px;
    font-weight: 800;
}

.terms {
    color: var(--muted);
    font-size: .85rem;
}

.rank-pill {
    width: 36px;
    height: 36px;
    border-radius: 10px;
    background: var(--primary);
    color: #fff;
    font-weight: 800;
    display: grid;
    place-items: center;
    box-shadow: 0 6px 14px var(--ring);
}

.about-section {
    background: linear-gradient(180deg, #f6fffb 0%, #f8fbff 100%);
    border-top: 1px solid rgba(2, 132, 199, .06);
    border-bottom: 1px solid rgba(2, 132, 199, .06);
}

.about-section .about-lead {
    font-size: clamp(1rem, 1.7vw, 1.25rem);
    color: var(--muted);
}


.section-dark {
    background: #0b1220;
    color: #e6edf6;
}

.section-dark .muted {
    color: #aab8d0;
}

.feature-item {
    border: 1px solid rgba(255, 255, 255, .08);
    border-radius: 16px;
    padding: 1.25rem;
    height: 100%;
    background: linear-gradient(180deg, rgba(255, 255, 255, .02), rgba(255, 255, 255, 0));
}

.icon-wrap {
    width: 56px;
    height: 56px;
    border-radius: 14px;
    display: grid;
    place-items: center;
    flex-shrink: 0;
    background: rgba(255, 255, 255, .06);
    border: 1px solid rgba(255, 255, 255, .08);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .02);
}

.icon-wrap svg {
    width: 28px;
    height: 28px;
    color: #7dd3fc;
}

.feature-item h3 {
    font-weight: 800;
    margin: 0 0 .25rem;
}

.feature-item p {
    margin: 0;
    color: #b6c3da;
}

.faq-section {
    background: var(--bg);
}

.faq-section .accordion {
    --bs-accordion-border-color: transparent;
    --bs-accordion-inner-border-radius: 14px;
}

.faq-section .accordion-item {
    background: transparent;
    border: 0;
    margin-bottom: 1rem;
    border-radius: 16px;
}

.faq-section .accordion-button {
    font-weight: 800;
    border-radius: 16px !important;
    padding: 1.1rem 1.25rem;
    box-shadow: 0 8px 20px rgba(2, 132, 199, .10);
    color: #f8fafc;
    background: #103557;
    border: 1px solid rgba(255, 255, 255, .1);
}

.faq-section .accordion-button:not(.collapsed) {
    background: #0f2f4d;
    color: #fff;
    box-shadow: 0 10px 24px rgba(2, 132, 199, .16);
}

.faq-section .accordion-button:focus {
    box-shadow: 0 0 0 .2rem var(--ring);
}

.faq-section .accordion-body {
    background: #0b1220;
    color: #e6edf6;
    border: 1px solid rgba(255, 255, 255, .08);
    border-top: 0;
    border-radius: 0 0 16px 16px;
    padding: 1.25rem;
}

.faq-section .accordion-body p {
    color: #b6c3da;
}

.faq-section .accordion-button::after {
    filter: invert(1) brightness(3);
}

@media (max-width: 575.98px) {
    .faq-section .accordion-button {
        padding: .95rem 1rem;
    }
}

#faq.faq-section .accordion-header .accordion-button {
    border-radius: 16px 16px 0 0 !important;
}

.site-footer {
    background: #0b1220;
    color: #dbe5f3;
    border-top: 1px solid rgba(2, 132, 199, .08);
}

.site-footer a {
    color: #cfe5ff;
    text-decoration: none;
}

.site-footer a:hover {
    color: #fff;
    text-decoration: underline;
}

.footer-brand {
    display: flex;
    align-items: center;
    gap: .75rem;
    text-decoration: none;
    color: #fff;
    font-weight: 900;
}

.footer-logo {
    width: 38px;
    height: 38px;
    border-radius: 12px;
    background: conic-gradient(from 210deg, #38bdf8, #99f6e4, #e0f2fe, #38bdf8);
    box-shadow: inset 0 0 0 4px rgba(255, 255, 255, .12);
}

.footer-top {
    padding-top: 2.5rem;
    padding-bottom: 2rem;
}

.footer-title {
    font-weight: 800;
    color: #e6edf6;
    margin-bottom: .8rem;
}

.footer-desc {
    color: #aebcd4;
}

.social a {
    width: 36px;
    height: 36px;
    display: grid;
    place-items: center;
    border-radius: 10px;
    background: rgba(255, 255, 255, .06);
    border: 1px solid rgba(255, 255, 255, .1);
}

.compliance {
    background: #103557;
    border-radius: 16px;
    border-top: 1px solid rgba(255, 255, 255, .08);
    border-bottom: 1px solid rgba(255, 255, 255, .08);
}

.compliance img {
    height: 32px;
}

.badge-pill {
    font-size: .8rem;
    font-weight: 800;
    padding: .35rem .6rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, .08);
    border: 1px solid rgba(255, 255, 255, .16);
    color: #e6edf6;
}

.copyright {
    color: #9fb0c9;
}

.age-modal {
    display: block;
    opacity: 1!important;
    backdrop-filter: blur(3px);
    background: #0008;
}

.age-modal .modal-content {
    border-radius: 20px;
    border: 1px solid rgba(2, 132, 199, .15);
    background: radial-gradient(140% 120% at 0% 0%, rgba(2, 132, 199, .10), transparent 40%), radial-gradient(120% 120% at 100% 0%, rgba(16, 185, 129, .10), transparent 40%), #ffffff;
    box-shadow: 0 36px 90px rgba(2, 132, 199, .22);
}

.age-modal .modal-header {
    background: linear-gradient(180deg, #0f2f4d, #103557);
    color: #fff;
    border-bottom: 1px solid rgba(255, 255, 255, .12);
    border-top-left-radius: 20px;
    border-top-right-radius: 20px;
}

.age-modal .modal-title {
    font-weight: 800;
}

.age-modal .modal-body {
    color: var(--muted);
}

.age-badge {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: #0f2f4d;
    color: #fff;
    font-weight: 900;
    box-shadow: 0 0 0 8px rgba(14, 165, 233, .18), 0 12px 28px rgba(2, 132, 199, .25);
}

.age-actions .btn {
    border-radius: 12px;
    padding: .9rem 1.1rem;
    font-weight: 800;
}

.age-actions .btn-decline {
    background: #e11d48;
    border-color: #e11d48;
}

.age-actions .btn-decline:hover {
    background: #be123c;
    border-color: #be123c;
}

.age-note {
    color: #6b778a;
    font-size: .9rem;
}

.age-chip {
    display: inline-flex;
    gap: .4rem;
    align-items: center;
    padding: .25rem .55rem;
    border-radius: 999px;
    background: rgba(2, 132, 199, .08);
    border: 1px solid rgba(2, 132, 199, .18);
    font-weight: 700;
    font-size: .8rem;
    color: #0f2f4d;
}