/* ============================================
   DE WITTE RAAF - DESIGN C: "Cozy Craftwork"
   Warm, gezellig, bordspelwinkel + café
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400;1,500&family=Inter:wght@300;400;500;600;700&display=swap');

html, body {
    overflow-x: hidden;
    max-width: 100vw;
}

/* === 1. ROOT VARIABLES, BASE, SCROLLBAR === */
:root {
    --rood: #B22234;
    --donkerrood: #8B1A2B;
    --diep-rood: #5C1420;
    --wit: #FFFDF9;
    --creme: #FDF6EE;
    --warmgrijs: #F5EDE3;
    --lichtgrijs: #FAF7F2;
    --tekst: #2C1810;
    --tekst-licht: #7A6B5E;
    --tekst-medium: #4A3C32;
    --goud: #D4A853;
    --bruin: #8B4513;
    --donkerbruin: #2C1810;
    --schaduw-sm: 0 2px 8px rgba(44,24,16,0.06);
    --schaduw-md: 0 4px 16px rgba(44,24,16,0.08);
    --schaduw-lg: 0 8px 32px rgba(44,24,16,0.10);
    --schaduw-xl: 0 16px 48px rgba(44,24,16,0.14);
    --schaduw-warm: 0 8px 32px rgba(178,34,52,0.12);
    --radius: 20px;
    --radius-sm: 10px;
    --transitie: 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

* { margin: 0; padding: 0; box-sizing: border-box; }

/* Custom Scrollbar */
::-webkit-scrollbar { width: 10px; }
::-webkit-scrollbar-track { background: var(--creme); }
::-webkit-scrollbar-thumb {
    background: linear-gradient(180deg, var(--rood), var(--donkerrood));
    border-radius: 10px;
    border: 2px solid var(--creme);
}
::-webkit-scrollbar-thumb:hover {
    background: linear-gradient(180deg, var(--donkerrood), var(--diep-rood));
}
@supports (scrollbar-color: auto) {
    html { scrollbar-color: var(--rood) var(--creme); scrollbar-width: thin; }
}

html { scroll-behavior: smooth; font-size: 16px; }

/* === 2. SCROLL PROGRESS BAR, PAGE TRANSITIONS === */
.raaf-scroll-progress {
    position: fixed;
    top: 0;
    left: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--rood), var(--goud));
    width: 0%;
    z-index: 9999;
    transition: width 0.05s linear;
    border-radius: 0 2px 2px 0;
}

body {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif !important;
    color: var(--tekst);
    background: var(--wit) !important;
    line-height: 1.75;
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
    animation: raafPageIn 1s ease both;
}

@keyframes raafPageIn {
    from { opacity: 0; transform: translateY(12px); }
    to { opacity: 1; transform: translateY(0); }
}

body.raaf-leaving {
    animation: raafPageOut 0.4s ease both;
}

@keyframes raafPageOut {
    from { opacity: 1; transform: translateY(0); }
    to { opacity: 0; transform: translateY(-12px); }
}

/* Back to Top */
.raaf-back-top {
    position: fixed;
    bottom: 32px;
    right: 32px;
    width: 48px;
    height: 48px;
    background: var(--rood);
    color: #fff;
    border: none;
    border-radius: var(--radius-sm);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 20px rgba(178,34,52,0.3);
    opacity: 0;
    visibility: hidden;
    transform: translateY(12px);
    transition: all 0.4s var(--transitie);
    z-index: 900;
}
.raaf-back-top.visible {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}
.raaf-back-top:hover {
    background: var(--donkerrood);
    transform: translateY(-3px);
    box-shadow: 0 6px 24px rgba(178,34,52,0.4);
}

h1, h2, h3, h4, h5, h6 {
    font-family: 'Playfair Display', Georgia, serif !important;
    font-weight: 700;
    line-height: 1.25;
    color: var(--tekst);
}

a { color: var(--rood); text-decoration: none; transition: color var(--transitie); }
a:hover { color: var(--donkerrood); }
img { max-width: 100%; height: auto; display: block; }

.container { max-width: 1140px; margin: 0 auto; padding: 0 24px; }

/* Scroll animations — slower, gentler */
.reveal { opacity: 0; transform: translateY(30px); transition: opacity 1s ease, transform 1s ease; }
.reveal.active { opacity: 1; transform: translateY(0); }
.reveal-left { opacity: 0; transform: translateX(-40px); transition: opacity 1s ease, transform 1s ease; }
.reveal-left.active { opacity: 1; transform: translateX(0); }
.reveal-right { opacity: 0; transform: translateX(40px); transition: opacity 1s ease, transform 1s ease; }
.reveal-right.active { opacity: 1; transform: translateX(0); }
.reveal-scale { opacity: 0; transform: scale(0.92); transition: opacity 1s ease, transform 1s ease; }
.reveal-scale.active { opacity: 1; transform: scale(1); }
.stagger-1 { transition-delay: 0.2s; }
.stagger-2 { transition-delay: 0.4s; }
.stagger-3 { transition-delay: 0.6s; }

/* === 3. ANNOUNCEMENT BANNER === */
.raaf-aankondiging {
    text-align: center;
    font-size: 0.84rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1001;
    background: linear-gradient(90deg, var(--diep-rood) 0%, var(--rood) 50%, var(--diep-rood) 100%);
    color: #fff;
    border-bottom: 1px solid rgba(178,34,52,0.3);
}
.aankondiging-inner {
    max-width: 1200px;
    margin: 0 auto;
    padding: 10px 48px 10px 24px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.aankondiging-inner button {
    position: absolute;
    right: 16px;
    background: none;
    border: none;
    color: inherit;
    font-size: 1.4rem;
    cursor: pointer;
    opacity: 0.7;
    transition: opacity 0.2s;
    line-height: 1;
}
.aankondiging-inner button:hover { opacity: 1; }

/* === 4. HEADER === */
.raaf-header {
    background: rgba(253,246,238,0.92);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-bottom: none;
    border-radius: 8px;
    position: fixed;
    top: 12px;
    left: 20px;
    right: 20px;
    z-index: 1000;
    transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    box-shadow: 0 2px 16px rgba(44,24,16,0.06);
}

body.heeft-aankondiging .raaf-header {
    top: calc(12px + var(--aankondiging-hoogte, 40px));
}
body.heeft-aankondiging .page-header {
    padding-top: calc(140px + var(--aankondiging-hoogte, 40px));
}
body.heeft-aankondiging .hero {
    padding-top: calc(120px + var(--aankondiging-hoogte, 40px));
}

.raaf-header.scrolled {
    box-shadow: 0 4px 30px rgba(44,24,16,0.12), 0 1px 3px rgba(44,24,16,0.06);
    background: rgba(253,246,238,0.98);
    border-radius: 8px;
}

.header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 28px;
    max-width: 1200px;
    margin: 0 auto;
    height: 68px;
    gap: 24px;
}

/* Logo */
.logo {
    display: flex;
    align-items: center;
    gap: 14px;
    text-decoration: none;
    flex-shrink: 0;
}
.logo img {
    height: 42px;
    width: auto;
    transition: transform 0.4s ease;
}
.logo:hover img { transform: rotate(-3deg) scale(1.05); }

.logo-text {
    font-family: 'Playfair Display', serif !important;
    font-size: 1.15rem;
    font-weight: 700;
    color: var(--rood);
    line-height: 1.15;
}
.logo-text small {
    display: block;
    font-family: 'Inter', sans-serif !important;
    font-size: 0.56rem;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 3px;
    color: var(--tekst-licht);
    margin-top: 2px;
}

/* Desktop nav */
.raaf-nav {
    display: flex;
    align-items: center;
}
.raaf-nav ul {
    display: flex;
    list-style: none;
    gap: 2px;
    align-items: center;
    margin: 0;
    padding: 0;
}
.raaf-nav a {
    color: var(--tekst-medium);
    font-weight: 500;
    font-size: 0.85rem;
    letter-spacing: 0.3px;
    padding: 10px 16px;
    border-radius: 8px;
    transition: all 0.3s ease;
    position: relative;
    text-decoration: none;
    display: flex;
    align-items: center;
}
.raaf-nav a::after {
    content: '';
    position: absolute;
    bottom: 6px;
    left: 16px;
    right: 16px;
    height: 2px;
    background: var(--rood);
    transform: scaleX(0);
    transition: transform 0.35s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    transform-origin: left;
    border-radius: 2px;
}
.raaf-nav a:hover { color: var(--rood); background: rgba(178,34,52,0.04); }
.raaf-nav a:hover::after { transform: scaleX(1); }
.raaf-nav a.active { color: var(--rood); font-weight: 600; }
.raaf-nav a.active::after { transform: scaleX(1); }

/* === MEGA MENU === */
.raaf-dropdown {
    position: relative;
}

.raaf-dropdown-trigger {
    display: flex;
    align-items: center;
    gap: 2px;
    color: var(--tekst-medium);
    font-weight: 500;
    font-size: 0.85rem;
    letter-spacing: 0.3px;
    padding: 10px 16px;
    border-radius: 8px;
    border: none;
    background: none;
    cursor: pointer;
    transition: all 0.3s ease;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
}

.raaf-dropdown-trigger:hover,
.raaf-dropdown.open .raaf-dropdown-trigger {
    color: var(--rood);
    background: rgba(178,34,52,0.04);
}

.raaf-dropdown.open .raaf-dropdown-trigger i {
    transform: rotate(180deg);
}

.raaf-mega-menu {
    position: absolute;
    top: calc(100% + 12px);
    left: 50%;
    transform: translateX(-50%) translateY(10px);
    background: var(--creme);
    border: 1px solid rgba(44,24,16,0.08);
    border-radius: 16px;
    padding: 14px;
    box-shadow: 0 20px 60px -12px rgba(44,24,16,0.18), 0 0 0 1px rgba(44,24,16,0.04);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
    z-index: 100;
    min-width: 320px;
}

.raaf-mega-menu::before {
    content: '';
    position: absolute;
    top: -8px;
    left: 50%;
    transform: translateX(-50%) rotate(45deg);
    width: 14px;
    height: 14px;
    background: var(--creme);
    border-top: 1px solid rgba(44,24,16,0.08);
    border-left: 1px solid rgba(44,24,16,0.08);
    border-radius: 3px 0 0 0;
}

.raaf-dropdown.open .raaf-mega-menu {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateX(-50%) translateY(0);
}

.mega-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 4px;
}

.mega-item {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 12px 16px;
    border-radius: 12px;
    text-decoration: none;
    color: var(--tekst);
    transition: all 0.25s ease;
}

.mega-item:hover {
    background: rgba(178,34,52,0.05);
    transform: translateX(4px);
}

.mega-item.active {
    background: rgba(155,35,53,0.06);
}

.mega-item.active .mega-title {
    color: var(--rood);
}

.mega-icon {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: linear-gradient(135deg, rgba(178,34,52,0.10), rgba(178,34,52,0.04));
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    color: var(--rood);
}

.mega-icon i {
    width: 18px;
    height: 18px;
}

.mega-title {
    display: block;
    font-weight: 600;
    font-size: 0.88rem;
    color: var(--tekst);
    line-height: 1.3;
}

.mega-desc {
    display: block;
    font-size: 0.76rem;
    color: var(--tekst-licht);
    line-height: 1.3;
    margin-top: 1px;
}

/* CTA in header */
.header-cta {
    display: inline-flex;
    align-items: center;
    padding: 10px 24px;
    background: linear-gradient(135deg, var(--rood), var(--donkerrood));
    color: var(--creme) !important;
    font-size: 0.82rem;
    font-weight: 600;
    border-radius: var(--radius-sm);
    text-decoration: none;
    transition: all 0.3s ease;
    white-space: nowrap;
    flex-shrink: 0;
    box-shadow: 0 2px 8px rgba(155,35,53,0.2);
    letter-spacing: 0.3px;
}
.header-cta:hover {
    background: linear-gradient(135deg, var(--donkerrood), var(--diep-rood));
    transform: translateY(-1px);
    box-shadow: 0 4px 16px rgba(155,35,53,0.3);
    color: var(--creme) !important;
}

/* Hamburger */
.menu-toggle {
    display: none;
    background: none;
    border: 1.5px solid rgba(44,24,16,0.12);
    cursor: pointer;
    padding: 0;
    width: 44px;
    height: 44px;
    border-radius: 10px;
    position: relative;
    transition: all 0.25s;
    flex-shrink: 0;
}
.menu-toggle:hover { border-color: var(--rood); background: rgba(178,34,52,0.04); }
.menu-toggle span {
    position: absolute;
    left: 12px;
    width: 20px;
    height: 3px;
	opacity: 0.8;
    background: var(--tekst);
    border-radius: 2px;
    transition: all 0.3s cubic-bezier(0.68,-0.55,0.265,1.55);
}
.menu-toggle span:nth-child(1) { top: 14px; }
.menu-toggle span:nth-child(2) { top: 21px; }
.menu-toggle span:nth-child(3) { top: 28px; }
.menu-toggle.open { border-color: var(--rood); }
.menu-toggle.open span { background: var(--rood); }
.menu-toggle.open span:nth-child(1) { top: 21px; transform: rotate(45deg); }
.menu-toggle.open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.menu-toggle.open span:nth-child(3) { top: 21px; transform: rotate(-45deg); }

/* === 5. MOBILE MENU — slides from LEFT === */
.mobile-menu-overlay,
.mobile-menu {
    display: none;
}

@media (max-width: 768px) {
    .mobile-menu-overlay {
        display: block;
        position: fixed;
        inset: 0;
        background: rgba(44,24,16,0.4);
        backdrop-filter: blur(4px);
        z-index: 1100;
        opacity: 0;
        visibility: hidden;
        transition: all 0.4s ease;
    }
    .mobile-menu-overlay.open {
        opacity: 1;
        visibility: visible;
    }

    .mobile-menu {
        display: flex;
        position: fixed;
        top: 0;
        left: 0;
        bottom: 0;
        width: 320px;
        max-width: 85vw;
        background: var(--creme);
        z-index: 1200;
        transform: translateX(-100%);
        transition: transform 0.45s cubic-bezier(0.25, 0.46, 0.45, 0.94);
        flex-direction: column;
        box-shadow: 8px 0 40px rgba(44,24,16,0.15);
        border-radius: 0 20px 20px 0;
    }
    .mobile-menu.open {
        transform: translateX(0);
    }
}

.mobile-menu-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 24px;
    border-bottom: 1px solid rgba(44,24,16,0.08);
}
.mobile-menu-header .logo-text {
    font-size: 1rem;
}
.mobile-close {
    background: none;
    border: none;
    font-size: 2rem;
    color: var(--tekst-licht);
    cursor: pointer;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
    transition: all 0.2s;
    line-height: 1;
}
.mobile-close:hover { background: rgba(155,35,53,0.08); color: var(--rood); }

.mobile-nav {
    flex: 1;
    padding: 16px;
    overflow-y: auto;
}
.mobile-nav a {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 16px;
    color: var(--tekst);
    text-decoration: none;
    font-weight: 500;
    font-size: 0.95rem;
    border-radius: 10px;
    transition: all 0.25s;
    margin-bottom: 2px;
    opacity: 0;
    transform: translateX(-12px);
}
.mobile-menu.open .mobile-nav a {
    opacity: 1;
    transform: translateX(0);
    transition: all 0.35s ease;
}

.menu-toggle span:nth-child(1) { top: 10px; }
.menu-toggle span:nth-child(2) { top: 17px; }
.menu-toggle span:nth-child(3) { top: 24px; }
.menu-toggle.open span:nth-child(1) { top: 17px; }
.menu-toggle.open span:nth-child(3) { top: 17px; }

.mobile-menu.open .mobile-nav a:nth-child(1) { transition-delay: 0.08s; }
.mobile-menu.open .mobile-nav a:nth-child(2) { transition-delay: 0.12s; }
.mobile-menu.open .mobile-nav a:nth-child(3) { transition-delay: 0.16s; }
.mobile-menu.open .mobile-nav a:nth-child(4) { transition-delay: 0.20s; }
.mobile-menu.open .mobile-nav a:nth-child(5) { transition-delay: 0.24s; }
.mobile-menu.open .mobile-nav a:nth-child(6) { transition-delay: 0.28s; }
.mobile-menu.open .mobile-nav a:nth-child(7) { transition-delay: 0.32s; }
.mobile-menu.open .mobile-nav a:nth-child(8) { transition-delay: 0.36s; }
.mobile-nav a:hover { background: rgba(178,34,52,0.06); color: var(--rood); }
.mobile-nav a.active {
    background: rgba(155,35,53,0.08);
    color: var(--rood);
    font-weight: 600;
}

.mobile-menu-footer {
    padding: 20px 24px;
    border-top: 1px solid rgba(44,24,16,0.08);
}
.mobile-cta {
    display: block;
    text-align: center;
    padding: 14px;
    background: linear-gradient(135deg, var(--rood), var(--donkerrood));
    color: var(--creme) !important;
    font-weight: 700;
    font-size: 0.9rem;
    border-radius: var(--radius-sm);
    text-decoration: none;
    transition: all 0.3s;
    margin-bottom: 16px;
    box-shadow: 0 2px 12px rgba(155,35,53,0.25);
}
.mobile-cta:hover { background: linear-gradient(135deg, var(--donkerrood), var(--diep-rood)); }

.mobile-contact {
    margin-bottom: 12px;
}
.mobile-contact p {
    font-size: 0.8rem;
    color: var(--tekst-licht);
    margin: 0 0 4px;
    line-height: 1.5;
}
.mobile-contact a { color: var(--rood); text-decoration: none; }

.mobile-socials {
    display: flex;
    gap: 12px;
}
.mobile-socials a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: 10px;
    background: rgba(44,24,16,0.06);
    color: var(--tekst-licht);
    transition: all 0.25s;
    text-decoration: none;
}
.mobile-socials a:hover { background: rgba(155,35,53,0.10); color: var(--rood); }

/* === 6. HERO === */
.hero {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    position: relative;
    overflow: hidden;
    background: linear-gradient(160deg, #3D1518 0%, #8B1A2B 30%, #B22234 55%, #7A1C2A 80%, #4A1520 100%);
    padding: 120px 24px 80px;
}

.hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse 80% 50% at 15% 85%, rgba(200,148,62,0.18) 0%, transparent 60%),
        radial-gradient(ellipse 50% 40% at 85% 15%, rgba(253,246,238,0.06) 0%, transparent 50%),
        radial-gradient(ellipse 40% 30% at 50% 50%, rgba(155,35,53,0.08) 0%, transparent 60%);
}

/* Subtle dice pattern overlay on hero */
.hero::after {
    content: '';
    position: absolute;
    inset: 0;
    background: url("data:image/svg+xml,%3Csvg width='200' height='200' viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%23ffffff' stroke-opacity='0.025' stroke-width='0.8'%3E%3Crect x='20' y='20' width='18' height='18' rx='3'/%3E%3Ccircle cx='29' cy='29' r='2'/%3E%3Crect x='160' y='140' width='18' height='18' rx='3'/%3E%3Ccircle cx='165' cy='145' r='1.5'/%3E%3Ccircle cx='173' cy='153' r='1.5'/%3E%3Ccircle cx='165' cy='153' r='1.5'/%3E%3Ccircle cx='173' cy='145' r='1.5'/%3E%3C/g%3E%3C/svg%3E");
}

.hero-content { position: relative; z-index: 2; max-width: 780px; }

.hero-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgba(253,246,238,0.10);
    backdrop-filter: blur(10px);
    border: 1px solid rgba(253,246,238,0.15);
    padding: 8px 22px;
    border-radius: var(--radius-sm);
    font-size: 0.8rem;
    font-weight: 500;
    color: rgba(253,246,238,0.9);
    letter-spacing: 1.5px;
    text-transform: uppercase;
    margin-bottom: 28px;
    animation: fadeInDown 1s ease 0.3s both;
}

.hero-badge::before {
    content: '';
    width: 6px; height: 6px;
    background: var(--goud);
    border-radius: 50%;
    animation: pulse-dot 2.5s infinite;
}

@keyframes pulse-dot {
    0%, 100% { opacity: 1; transform: scale(1); }
    50% { opacity: 0.4; transform: scale(1.6); }
}

.hero h1 {
    font-size: clamp(2.5rem, 6vw, 4rem);
    color: var(--creme) !important;
    margin-bottom: 20px;
    font-weight: 800;
    letter-spacing: -0.5px;
    animation: fadeInUp 1s ease 0.5s both;
}

.hero h1 em { font-style: italic; color: var(--goud); }

.hero-subtitle {
    font-size: clamp(1.05rem, 2vw, 1.3rem);
    color: rgba(253,246,238,0.80);
    margin-bottom: 36px;
    font-weight: 300;
    line-height: 1.8;
    animation: fadeInUp 1s ease 0.7s both;
}

.hero-buttons {
    display: flex;
    gap: 16px;
    justify-content: center;
    flex-wrap: wrap;
    animation: fadeInUp 1s ease 0.9s both;
}

@keyframes fadeInUp {
    from { opacity: 0; transform: translateY(30px); }
    to { opacity: 1; transform: translateY(0); }
}

@keyframes fadeInDown {
    from { opacity: 0; transform: translateY(-20px); }
    to { opacity: 1; transform: translateY(0); }
}

/* === 7. BUTTONS === */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 16px 36px;
    border-radius: var(--radius-sm);
    font-weight: 600;
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    transition: all var(--transitie);
    cursor: pointer;
    border: 2px solid transparent;
}

.btn-primary {
    background: var(--creme);
    color: var(--rood);
    box-shadow: 0 2px 8px rgba(44,24,16,0.08);
}
.btn-primary:hover {
    background: #fff;
    color: var(--donkerrood);
    transform: translateY(-2px);
    box-shadow: 0 8px 32px rgba(44,24,16,0.15);
}

.btn-outline {
    background: transparent;
    color: var(--creme);
    border-color: rgba(253,246,238,0.35);
}
.btn-outline:hover {
    background: rgba(253,246,238,0.12);
    border-color: var(--creme);
    color: var(--creme);
    transform: translateY(-2px);
    box-shadow: 0 4px 20px rgba(0,0,0,0.15);
}

.btn-rood {
    background: linear-gradient(135deg, var(--rood), var(--donkerrood));
    color: var(--creme);
    border-color: var(--rood);
    box-shadow: 0 2px 8px rgba(155,35,53,0.2);
}
.btn-rood:hover {
    background: linear-gradient(135deg, var(--donkerrood), var(--diep-rood));
    border-color: var(--donkerrood);
    color: var(--creme);
    transform: translateY(-2px);
    box-shadow: 0 8px 32px rgba(155,35,53,0.3);
}

.btn-rood-outline {
    background: transparent;
    color: var(--rood);
    border-color: var(--rood);
}
.btn-rood-outline:hover {
    background: var(--rood);
    color: var(--creme);
    transform: translateY(-2px);
    box-shadow: 0 4px 20px rgba(155,35,53,0.25);
}

.btn svg { width: 16px; height: 16px; transition: transform 0.3s; }
.btn:hover svg { transform: translateX(3px); }

/* === 8. SECTIONS === */
section { padding: 100px 24px; position: relative; }
/* Subtle board game dice pattern on cream sections */
.sectie-creme {
    background: var(--creme);
    background-image: url("data:image/svg+xml,%3Csvg width='120' height='120' viewBox='0 0 120 120' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%232C1810' fill-opacity='0.018'%3E%3Crect x='50' y='50' width='20' height='20' rx='3'/%3E%3Ccircle cx='56' cy='56' r='1.5'/%3E%3Ccircle cx='64' cy='64' r='1.5'/%3E%3C/g%3E%3C/svg%3E");
}
/* Subtle meeple pattern on warm grey sections */
.sectie-warmgrijs {
    background: var(--warmgrijs);
    background-image: url("data:image/svg+xml,%3Csvg width='160' height='160' viewBox='0 0 160 160' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%232C1810' fill-opacity='0.015'%3E%3Cpath d='M80 70c-3 0-5-2-5-5s2-5 5-5 5 2 5 5-2 5-5 5zm-6 2h12l2 8H72l2-8z'/%3E%3C/g%3E%3C/svg%3E");
}

.sectie-rood {
    background: linear-gradient(160deg, var(--diep-rood) 0%, var(--rood) 50%, var(--donkerrood) 100%);
    color: var(--creme);
    position: relative;
    overflow: hidden;
}

.sectie-rood::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        url("data:image/svg+xml,%3Csvg width='180' height='180' viewBox='0 0 180 180' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' stroke='%23ffffff' stroke-opacity='0.03' stroke-width='0.6'%3E%3Crect x='80' y='80' width='16' height='16' rx='2.5'/%3E%3Ccircle cx='85' cy='85' r='1.2'/%3E%3Ccircle cx='91' cy='91' r='1.2'/%3E%3C/g%3E%3C/svg%3E"),
        radial-gradient(ellipse 50% 50% at 80% 20%, rgba(255,255,255,0.04) 0%, transparent 60%);
}

.sectie-rood > * { position: relative; z-index: 1; }
.sectie-rood h2, .sectie-rood h3, .sectie-rood p, .sectie-rood a:not(.btn) { color: var(--creme); }

/* === 9. SECTION HEADERS === */
.section-header { text-align: center; margin-bottom: 56px; }

.section-label {
    display: inline-block;
    font-family: 'Playfair Display', serif !important;
    font-size: 0.88rem;
    font-weight: 500;
    font-style: italic;
    text-transform: none;
    letter-spacing: 1px;
    color: var(--rood);
    margin-bottom: 12px;
    position: relative;
    padding: 0 16px;
}

.section-label::before,
.section-label::after {
    content: '';
    position: absolute;
    top: 50%;
    width: 20px;
    height: 1px;
    background: currentColor;
    opacity: 0.3;
}
.section-label::before { right: 100%; }
.section-label::after { left: 100%; }

.sectie-rood .section-label { color: var(--goud); }
.sectie-rood .section-label::before,
.sectie-rood .section-label::after { background: var(--goud); }

.section-title { font-size: clamp(1.8rem, 4vw, 2.6rem); margin-bottom: 16px; letter-spacing: -0.3px; }

/* Wavy accent line using SVG */
.accent-line {
    width: 80px;
    height: 8px;
    margin: 0 auto 20px;
    background: none;
    background-image: url("data:image/svg+xml,%3Csvg width='80' height='8' viewBox='0 0 80 8' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 4 Q10 0 20 4 Q30 8 40 4 Q50 0 60 4 Q70 8 80 4' stroke='%23B22234' stroke-width='2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: center;
    border-radius: 0;
}
.sectie-rood .accent-line {
    background-image: url("data:image/svg+xml,%3Csvg width='80' height='8' viewBox='0 0 80 8' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 4 Q10 0 20 4 Q30 8 40 4 Q50 0 60 4 Q70 8 80 4' stroke='%23C8943E' stroke-width='2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
}

.section-subtitle {
    color: var(--tekst-licht);
    font-size: 1.1rem;
    max-width: 620px;
    margin: 0 auto;
    line-height: 1.8;
}

.sectie-rood .section-subtitle { color: rgba(253,246,238,0.75); }

/* === 10. GRID === */
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 40px; align-items: center; }

/* === 11. CARDS === */
.kaart {
    background: var(--creme);
    border-radius: var(--radius);
    padding: 40px 32px;
    text-align: center;
    box-shadow: var(--schaduw-sm);
    transition: all var(--transitie);
    position: relative;
    overflow: hidden;
    border: 1px solid rgba(44,24,16,0.05);
}

/* No top gradient bar — small colored dot accent instead */
.kaart::before {
    content: '';
    position: absolute;
    top: 20px;
    left: 50%;
    transform: translateX(-50%);
    width: 8px;
    height: 8px;
    background: var(--rood);
    border-radius: 50%;
    transition: all var(--transitie);
}

.kaart:hover {
    transform: translateY(-4px);
    box-shadow: 0 0 0 1px rgba(155,35,53,0.06), 0 12px 40px rgba(44,24,16,0.10);
}
.kaart:hover::before {
    width: 12px;
    height: 12px;
    background: var(--donkerrood);
}

.kaart-icon {
    width: 72px; height: 72px;
    margin: 12px auto 20px;
    display: flex; align-items: center; justify-content: center;
    font-size: 2rem;
    background: linear-gradient(135deg, rgba(178,34,52,0.08), rgba(178,34,52,0.03));
    border-radius: 50%;
    transition: all var(--transitie);
    border: 1px solid rgba(178,34,52,0.06);
}

.kaart-icon svg { width: 32px; height: 32px; color: var(--rood); stroke-width: 1.5; transition: all 0.4s; }

.kaart:hover .kaart-icon { background: linear-gradient(135deg, rgba(178,34,52,0.15), rgba(178,34,52,0.06)); transform: scale(1.06); border-color: rgba(178,34,52,0.12); }
.kaart:hover .kaart-icon svg { color: var(--donkerrood); }
.kaart h3 { color: var(--tekst); font-size: 1.2rem; margin-bottom: 12px; }
.kaart p { color: var(--tekst-licht); font-size: 0.95rem; line-height: 1.7; }

/* === 12. SPEL TAGS === */
.spel-tag {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 4px 12px;
    background: rgba(44,24,16,0.06);
    border-radius: var(--radius-sm);
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--tekst-licht);
}

.spel-afbeelding {
    overflow: hidden;
    border-radius: 16px;
    margin-bottom: 16px;
}

.spel-afbeelding img {
    transition: transform 0.5s ease;
}

.kaart:hover .spel-afbeelding img {
    transform: scale(1.04);
}

/* === 13. STATS BAR === */
.stats-bar {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    background: var(--creme);
    border-radius: var(--radius);
    box-shadow: var(--schaduw-lg);
    overflow: hidden;
    max-width: 900px;
    margin: -60px auto 0;
    position: relative;
    z-index: 10;
    border: 1px solid rgba(44,24,16,0.06);
}

.stat {
    text-align: center;
    padding: 36px 20px;
    border-right: 1px solid rgba(44,24,16,0.06);
    transition: all var(--transitie);
    position: relative;
}

.stat:last-child { border-right: none; }
.stat:hover { background: rgba(178,34,52,0.04); }
.stat:hover .stat-number { color: var(--donkerrood); }

.stat-number {
    font-family: 'Playfair Display', serif !important;
    font-size: 2.2rem; font-weight: 800;
    color: var(--rood);
    line-height: 1; margin-bottom: 6px;
    transition: color 0.3s ease;
}

.stat-label {
    font-size: 0.78rem; text-transform: uppercase;
    letter-spacing: 1.5px; color: var(--tekst-licht); font-weight: 500;
}

/* === 14. FEATURE ROW === */
.feature-row { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; margin-bottom: 80px; }
.feature-row:last-child { margin-bottom: 0; }

.feature-visual {
    border-radius: var(--radius);
    overflow: hidden;
    aspect-ratio: 4/3;
    display: flex; align-items: center; justify-content: center;
    color: var(--tekst-licht);
    font-size: 0.95rem;
    transition: transform var(--transitie);
}

.feature-visual:hover { transform: scale(1.02); }
.feature-content h3 { font-size: 1.6rem; margin-bottom: 16px; }
.feature-content p { color: var(--tekst-licht); font-size: 1.05rem; line-height: 1.8; margin-bottom: 24px; }
.feature-list { list-style: none; }
.feature-list li { padding: 8px 0; padding-left: 28px; position: relative; color: var(--tekst-medium); }
.feature-list li::before { content: ''; position: absolute; left: 0; top: 16px; width: 8px; height: 8px; background: var(--rood); border-radius: 50%; }

/* === 15. OPENING HOURS === */
.openingstijden {
    max-width: 500px; margin: 0 auto;
    border-radius: var(--radius); overflow: hidden;
    box-shadow: var(--schaduw-lg); border: 1px solid rgba(44,24,16,0.06);
}

.openingstijden table { width: 100%; border-collapse: collapse; }

.openingstijden th {
    background: linear-gradient(135deg, var(--rood), var(--donkerrood));
    color: #fff; padding: 18px 24px; text-align: left;
    font-family: 'Playfair Display', serif !important; font-size: 1.1rem; font-weight: 600;
}

.openingstijden td {
    padding: 14px 24px; border-bottom: 1px solid rgba(44,24,16,0.05);
    background: var(--creme); font-size: 0.95rem; transition: background var(--transitie);
}

.openingstijden tr:hover td { background: rgba(200,148,62,0.08); }
.openingstijden tr:last-child td { border-bottom: none; }
.openingstijden .gesloten { color: var(--tekst-licht); font-style: italic; }
.openingstijden .dag { font-weight: 600; color: var(--tekst); }

/* === UREN TABS / SWITCHER === */
.uren-switcher {
    max-width: 520px;
    margin: 0 auto;
    background: var(--creme);
    border-radius: var(--radius);
    padding: 32px 36px;
    box-shadow: var(--schaduw-md);
    border: 1px solid rgba(44,24,16,0.06);
}
.uren-tabs-center {
    display: flex;
    justify-content: center;
    gap: 4px;
    background: rgba(44,24,16,0.06);
    border-radius: var(--radius-sm);
    padding: 4px;
    margin-bottom: 28px;
}
.uren-tab-pill {
    background: none;
    border: none;
    padding: 10px 28px;
    border-radius: var(--radius-sm);
    font-size: 0.88rem;
    font-weight: 600;
    color: var(--tekst-licht);
    cursor: pointer;
    transition: all 0.25s;
    font-family: inherit;
}
.uren-tab-pill.active {
    background: var(--rood);
    color: #fff;
    box-shadow: 0 2px 10px rgba(178,34,52,0.3);
}
.uren-tab-pill:hover:not(.active) {
    color: var(--tekst);
}
.uren-lijst {
    display: flex;
    flex-direction: column;
    gap: 0;
}
.uren-rij {
    display: flex;
    align-items: center;
    padding: 14px 0;
    border-bottom: 1px solid rgba(44,24,16,0.06);
}
.uren-rij:last-child { border-bottom: none; }
.uren-vandaag {
    background: rgba(178,34,52,0.05);
    margin: 0 -20px;
    padding: 14px 20px;
    border-radius: 10px;
    border-bottom-color: transparent;
}
.uren-dag {
    font-weight: 700;
    font-size: 0.9rem;
    color: var(--tekst);
    min-width: 120px;
    display: flex;
    align-items: center;
    gap: 8px;
}
.uren-dot {
    width: 8px;
    height: 8px;
    background: var(--rood);
    border-radius: 50%;
    display: inline-block;
    animation: urenPulse 2.5s ease infinite;
}
@keyframes urenPulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.3; }
}
.uren-lijn {
    flex: 1;
    height: 1px;
    background: repeating-linear-gradient(
        90deg,
        rgba(44,24,16,0.12) 0px,
        rgba(44,24,16,0.12) 4px,
        transparent 4px,
        transparent 8px
    );
    margin: 0 16px;
}
.uren-tijd {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--tekst);
}
.uren-dicht {
    color: var(--rood);
    font-style: italic;
    font-weight: 500;
}

/* Uren tabs (winkel/cafe switcher) */
.uren-tabs {
    display: inline-flex;
    gap: 4px;
    background: rgba(44,24,16,0.10);
    border-radius: 8px;
    padding: 3px;
    margin-bottom: 10px;
}
.uren-tab {
    background: none;
    border: none;
    color: rgba(253,246,238,0.5);
    padding: 6px 14px;
    border-radius: 6px;
    font-size: 0.78rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.25s;
    font-family: inherit;
}
.uren-tab.active {
    background: var(--rood);
    color: #fff;
}
.uren-tab:hover:not(.active) {
    color: rgba(253,246,238,0.8);
}
.uren-content {
    display: none;
}
.uren-content.active {
    display: block;
}

.sectie-warmgrijs .uren-tabs,
.sectie-creme .uren-tabs,
.contact-info-kaart .uren-tabs {
    background: rgba(44,24,16,0.08);
}
.sectie-warmgrijs .uren-tab,
.sectie-creme .uren-tab,
.contact-info-kaart .uren-tab {
    color: rgba(44,24,16,0.4);
}
.sectie-warmgrijs .uren-tab.active,
.sectie-creme .uren-tab.active,
.contact-info-kaart .uren-tab.active {
    background: var(--rood);
    color: #fff;
}

/* === 16. PAGE HEADER === */
.page-header {
    background: linear-gradient(160deg, var(--diep-rood) 0%, var(--rood) 40%, var(--donkerrood) 100%);
    color: var(--creme); text-align: center; padding: 140px 24px 70px;
    position: relative; overflow: hidden;
}

.page-header::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        url("data:image/svg+xml,%3Csvg width='100' height='100' viewBox='0 0 100 100' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff' fill-opacity='0.02'%3E%3Ccircle cx='50' cy='50' r='1.5'/%3E%3C/g%3E%3C/svg%3E"),
        radial-gradient(ellipse 60% 50% at 80% 80%, rgba(200,148,62,0.10) 0%, transparent 60%);
}

.page-header > * { position: relative; z-index: 1; }
.page-header h1 { font-size: clamp(2rem, 5vw, 3rem); color: var(--creme) !important; margin-bottom: 12px; animation: fadeInUp 1s ease both; letter-spacing: -0.3px; }
.page-header p { font-size: 1.15rem; color: rgba(253,246,238,0.75); animation: fadeInUp 1s ease 0.3s both; }
.page-header .section-label { color: var(--goud); }
.page-header .section-label::before,
.page-header .section-label::after { background: var(--goud); }

/* === 17. PRIVACY === */
.privacy-content { padding: 20px 0 40px; }
.privacy-intro { font-size: 1.05rem; line-height: 1.8; color: var(--tekst-medium); margin-bottom: 36px; }
.privacy-blok {
    display: flex;
    gap: 20px;
    padding: 28px;
    margin-bottom: 16px;
    background: var(--creme);
    border-radius: var(--radius);
    border: 1px solid rgba(44,24,16,0.05);
    transition: box-shadow 0.4s;
}
.privacy-blok:hover { box-shadow: var(--schaduw-md); }
.privacy-icon {
    width: 48px;
    height: 48px;
    background: rgba(178,34,52,0.08);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.privacy-blok h3 { font-family: 'Playfair Display', serif; font-size: 1.1rem; color: var(--tekst); margin-bottom: 8px; }
.privacy-blok p { font-size: 0.92rem; line-height: 1.7; color: var(--tekst-licht); }
.privacy-blok ul { list-style: none; padding: 0; margin: 8px 0 0; }
.privacy-blok ul li {
    position: relative;
    padding-left: 20px;
    font-size: 0.9rem;
    line-height: 2;
    color: var(--tekst-licht);
}
.privacy-blok ul li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 6px;
    height: 6px;
    background: var(--rood);
    border-radius: 50%;
}
.privacy-update { text-align: center; font-size: 0.8rem; color: var(--tekst-licht); margin-top: 36px; opacity: 0.6; }

@media (max-width: 600px) {
    .privacy-blok { flex-direction: column; gap: 12px; padding: 20px; }
}

/* === 18. FOOTER === */
.raaf-footer {
    background: linear-gradient(180deg, #2C1810 0%, #1E110B 100%);
    color: rgba(253,246,238,0.55);
    position: relative;
    overflow: hidden;
}

.raaf-footer::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: linear-gradient(90deg, transparent, var(--rood) 30%, var(--goud) 50%, var(--rood) 70%, transparent);
}

.footer-top {
    padding: 100px 32px 48px;
    max-width: 1200px;
    margin: 0 auto;
}

.footer-grid {
    display: grid;
    grid-template-columns: 1.6fr 0.8fr 1fr 1.1fr;
    gap: 48px;
}

.footer-brand .logo { margin-bottom: 4px; }
.footer-desc {
    margin-top: 16px;
    font-size: 0.88rem;
    line-height: 1.8;
    color: rgba(253,246,238,0.45);
}

.footer-social {
    display: flex;
    gap: 10px;
    margin-top: 24px;
}

.footer-social a {
    width: 38px; height: 38px;
    border-radius: 10px;
    background: rgba(253,246,238,0.06);
    border: 1px solid rgba(253,246,238,0.06);
    display: flex; align-items: center; justify-content: center;
    color: rgba(253,246,238,0.45);
    transition: all 0.3s ease;
}
.footer-social a svg { width: 18px; height: 18px; }
.footer-social a:hover {
    background: var(--rood);
    border-color: var(--rood);
    color: #fff;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(178,34,52,0.3);
}

.raaf-footer h4 {
    color: var(--creme);
    font-family: 'Playfair Display', serif !important;
    font-size: 0.85rem;
    font-weight: 600;

    text-transform: none;
    letter-spacing: 0.5px;
    margin-bottom: 24px;
    position: relative;
    padding-bottom: 14px;
}
.raaf-footer h4::after {
    content: '';
    position: absolute;
    bottom: 0; left: 0;
    width: 24px; height: 2px;
    background: var(--rood);
    border-radius: 2px;
}

.footer-col ul { list-style: none; margin: 0; padding: 0; }
.footer-col li { margin-bottom: 0; }
.footer-col ul a {
    color: rgba(253,246,238,0.45);
    font-size: 0.88rem;
    text-decoration: none;
    transition: all 0.25s ease;
    display: block;
    padding: 6px 0;
}
.footer-col ul a:hover {
    color: #fff;
    padding-left: 6px;
}

.footer-hours { margin: 0; padding: 0; }
.footer-hours li {
    display: flex;
    justify-content: space-between;
    padding: 5px 0;
    font-size: 0.84rem;
    border-bottom: 1px solid rgba(253,246,238,0.04);
}
.footer-hours li:last-child { border-bottom: none; }
.footer-day {
    font-weight: 600;
    color: rgba(253,246,238,0.65);
}
.footer-time {
    color: rgba(253,246,238,0.40);
    font-variant-numeric: tabular-nums;
}
.footer-time.closed {
    color: rgba(248,113,113,0.7);
    font-style: italic;
    font-size: 0.82rem;
}

.footer-contact-item {
    display: flex;
    gap: 10px;
    margin-bottom: 14px;
    font-size: 0.88rem;
    color: rgba(253,246,238,0.45);
    line-height: 1.6;
}
.footer-contact-item a {
    color: rgba(253,246,238,0.45);
    text-decoration: none;
    transition: color 0.25s;
}
.footer-contact-item a:hover { color: #fff; }

.footer-cta {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-top: 20px;
    padding: 10px 22px;
    background: rgba(178,34,52,0.12);
    border: 1px solid rgba(178,34,52,0.2);
    color: #f87171 !important;
    font-size: 0.82rem;
    font-weight: 600;
    border-radius: 10px;
    text-decoration: none;
    transition: all 0.3s ease;
}
.footer-cta:hover {
    background: var(--rood);
    border-color: var(--rood);
    color: #fff !important;
    transform: translateY(-1px);
    box-shadow: 0 4px 16px rgba(178,34,52,0.3);
}

.footer-bottom {
    border-top: 1px solid rgba(253,246,238,0.06);
    padding: 20px 32px;
}
.footer-bottom-inner {
    max-width: 1200px;
    margin: 0 auto;
    text-align: center;
    font-size: 0.78rem;
    color: rgba(253,246,238,0.20);
}
.footer-sep {
    margin: 0 8px;
    opacity: 0.4;
}

/* === 19. CONTACT === */
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; max-width: 1000px; margin: 0 auto; }

.contact-info-kaart { display: flex; gap: 16px; padding: 20px 0; border-bottom: 1px solid rgba(44,24,16,0.06); }
.contact-info-kaart:last-child { border-bottom: none; }

.contact-icon {
    width: 48px; height: 48px;
    background: rgba(178,34,52,0.08);
    border-radius: 14px;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.2rem; flex-shrink: 0;
}

.contact-icon svg { width: 22px; height: 22px; color: var(--rood); stroke-width: 1.5; }

.contact-info-kaart h4 {
    font-family: 'Inter', sans-serif !important;
    font-size: 0.8rem; font-weight: 600;
    text-transform: uppercase; letter-spacing: 1px;
    color: var(--tekst-licht); margin-bottom: 4px;
}

.contact-info-kaart p { color: var(--tekst); font-size: 0.95rem; line-height: 1.6; }

.contact-form {
    background: var(--wit); border-radius: var(--radius); padding: 40px;
    box-shadow: var(--schaduw-lg); border: 1px solid rgba(0,0,0,0.04);
    max-width: 100%;
    width: 100%;
    box-sizing: border-box;
    overflow-x: hidden;
}

.contact-form h3 { margin-bottom: 28px; font-size: 1.4rem; }

.form-group { margin-bottom: 20px; }
.form-group label { display: block; font-weight: 500; font-size: 0.85rem; margin-bottom: 8px; color: var(--tekst-medium); }

.form-group input,
.form-group textarea,
.form-group select {
    width: 100%; padding: 14px 18px;
    border: 1px solid rgba(44,24,16,0.10); border-radius: var(--radius-sm);
    font-family: 'Inter', sans-serif; font-size: 0.95rem;
    transition: all var(--transitie); background: var(--wit);
}

.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus {
    outline: none; border-color: var(--rood);
    box-shadow: 0 0 0 4px rgba(178,34,52,0.08); background: #fff;
}

.form-group textarea { height: 140px; resize: vertical; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }

/* === 20. REVIEWS === */
.review-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }

.review-kaart {
    background: var(--creme); border-radius: var(--radius); padding: 36px;
    box-shadow: var(--schaduw-sm); border: 1px solid rgba(44,24,16,0.05); transition: all var(--transitie);
}

.review-kaart:hover { box-shadow: var(--schaduw-warm); transform: translateY(-4px); }
.review-stars { color: var(--goud); font-size: 1.1rem; margin-bottom: 16px; letter-spacing: 2px; }
.review-tekst { font-size: 0.95rem; color: var(--tekst-medium); line-height: 1.8; margin-bottom: 20px; font-style: italic; }
.review-auteur { font-weight: 600; font-size: 0.85rem; color: var(--tekst); }
.review-bron { font-size: 0.75rem; color: var(--tekst-licht); }

/* === 21. MAP === */
.map-container {
    border-radius: var(--radius); overflow: hidden; height: 400px;
    background: var(--warmgrijs); display: flex; align-items: center; justify-content: center;
    color: var(--tekst-licht); box-shadow: var(--schaduw-md);
    border: 1px solid rgba(44,24,16,0.06); max-width: 900px; margin: 0 auto;
}

/* === 22. COOKIE NOTICE === */
.raaf-cookie-notice {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    background: var(--donkerbruin);
    color: var(--creme);
    padding: 16px 24px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    z-index: 9999;
    font-size: 0.9rem;
    box-shadow: 0 -4px 20px rgba(44,24,16,0.25);
}

.raaf-cookie-notice p { margin: 0; flex: 1; color: rgba(253,246,238,0.8); }

.raaf-cookie-notice button {
    background: var(--rood);
    color: #fff;
    border: none;
    padding: 10px 24px;
    border-radius: var(--radius-sm);
    cursor: pointer;
    font-weight: 600;
    white-space: nowrap;
    transition: background 0.3s;
}

.raaf-cookie-notice button:hover { background: var(--donkerrood); }

@media (max-width: 600px) {
    .raaf-cookie-notice { flex-direction: column; text-align: center; }
}

/* === 23. STEPS === */
.stap-nummer {
    width: 52px;
    height: 52px;
    border-radius: 50%;
    background: linear-gradient(135deg, rgba(178,34,52,0.10), rgba(178,34,52,0.04));
    color: var(--rood);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'Playfair Display', serif !important;
    font-size: 1.3rem;
    font-weight: 700;
    margin: 0 auto 16px;
    border: 2px solid rgba(178,34,52,0.12);
    transition: all 0.4s ease;
}
.kaart:hover .stap-nummer {
    background: linear-gradient(135deg, var(--rood), var(--donkerrood));
    color: #fff;
    border-color: var(--rood);
    transform: scale(1.05);
}

/* === 24. VERHUUR === */
.verhuur-categorie {
    text-align: center;
    padding: 40px 28px;
}

.verhuur-tag {
    display: inline-block;
    background: rgba(178,34,52,0.08);
    color: var(--rood);
    font-size: 0.78rem;
    font-weight: 700;
    padding: 6px 16px;
    border-radius: var(--radius-sm);
    margin-top: 12px;
    letter-spacing: 0.5px;
}

.verhuur-prijzen { }

.prijs-kaart-groot {
    background: var(--creme);
    border-radius: var(--radius);
    overflow: hidden;
    max-width: 700px;
    margin: 0 auto;
    box-shadow: var(--schaduw-md);
    border: 1px solid rgba(44,24,16,0.06);
}

.prijs-rij {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 24px 32px;
    border-bottom: 1px solid rgba(44,24,16,0.06);
    gap: 20px;
}

.prijs-rij-label strong {
    display: block;
    font-size: 1rem;
    color: var(--tekst);
    margin-bottom: 2px;
}

.prijs-rij-label span {
    font-size: 0.82rem;
    color: var(--tekst-licht);
}

.prijs-rij-bedrag {
    text-align: right;
    flex-shrink: 0;
}

.prijs-groot {
    display: block;
    font-size: 1.4rem;
    font-weight: 800;
    color: var(--rood);
    letter-spacing: -0.02em;
}

.prijs-per {
    font-size: 0.78rem;
    color: var(--tekst-licht);
}

.voorwaarden-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
    max-width: 800px;
    margin: 0 auto;
}

.voorwaarde-kaart {
    background: var(--creme);
    border: 1px solid rgba(44,24,16,0.06);
    border-radius: var(--radius);
    padding: 28px;
    transition: all 0.4s;
}

.voorwaarde-kaart:hover {
    transform: translateY(-3px);
    box-shadow: var(--schaduw-md);
}

.voorwaarde-icon {
    width: 44px;
    height: 44px;
    background: rgba(178,34,52,0.08);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 16px;
    color: var(--rood);
}

.voorwaarde-kaart h4 {
    font-size: 1rem;
    margin-bottom: 8px;
    color: var(--tekst);
}

.voorwaarde-kaart p {
    font-size: 0.88rem;
    color: var(--tekst-licht);
    line-height: 1.7;
}

@media (max-width: 600px) {
    .voorwaarden-grid { grid-template-columns: 1fr; }
    .prijs-rij { flex-direction: column; text-align: center; gap: 8px; }
    .prijs-rij-bedrag { text-align: center; }
}

/* === 25. TEAM === */
.team-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }

.team-kaart {
    text-align: center;
    background: var(--creme);
    border-radius: var(--radius);
    padding: 32px 24px;
    transition: all var(--transitie);
    border: 1px solid rgba(44,24,16,0.05);
}

.team-kaart:hover {
    box-shadow: var(--schaduw-warm);
    transform: translateY(-4px);
}

.team-foto {
    width: 100%;
    height: 280px;
    border-radius: 16px;
    margin-bottom: 16px;
    overflow: hidden;
}

.team-foto img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.team-foto-placeholder {
    width: 100%;
    height: 280px;
    border-radius: 16px;
    margin-bottom: 16px;
    background: linear-gradient(135deg, var(--warmgrijs) 0%, rgba(200,148,62,0.10) 100%);
    display: flex;
    align-items: center;
    justify-content: center;
}

.team-info h3 {
    font-size: 1.1rem;
    margin-bottom: 4px;
}

.team-info p {
    font-size: 0.88rem;
    color: var(--tekst-licht);
    font-style: italic;
}

/* === 26. MENU ITEMS === */
.menu-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 28px; max-width: 800px; margin: 0 auto; }

.menu-kaart {
    background: var(--creme); border-radius: var(--radius); padding: 36px;
    box-shadow: var(--schaduw-sm); border: 1px solid rgba(44,24,16,0.05); transition: all var(--transitie);
}

.menu-kaart:hover { box-shadow: var(--schaduw-md); }
.menu-kaart h3 { color: var(--rood); margin-bottom: 16px; font-size: 1.2rem; }
.menu-kaart ul { list-style: none; }

.menu-kaart li {
    padding: 8px 0; border-bottom: 1px solid rgba(44,24,16,0.05);
    color: var(--tekst-medium); font-size: 0.95rem;
    display: flex; align-items: center; gap: 10px;
}

.menu-kaart li:last-child { border-bottom: none; }

/* === 27. PRICE CARD === */
.prijs-kaart {
    background: var(--creme); border-radius: var(--radius); padding: 48px;
    text-align: center; box-shadow: var(--schaduw-lg); max-width: 440px;
    margin: 0 auto; border: 1px solid rgba(44,24,16,0.06); position: relative; overflow: hidden;
}

.prijs-kaart::before {
    content: ''; position: absolute; top: 0; left: 0; right: 0;
    height: 4px; background: linear-gradient(90deg, var(--rood), var(--goud));
}

.prijs-label { font-size: 0.8rem; text-transform: uppercase; letter-spacing: 2px; color: var(--tekst-licht); font-weight: 600; margin-bottom: 8px; }
.prijs-bedrag { font-family: 'Playfair Display', serif !important; font-size: 2.5rem; font-weight: 800; color: var(--rood); margin-bottom: 8px; }
.prijs-detail { color: var(--tekst-licht); font-size: 0.9rem; }

/* === 28. CONTACT SUCCESS, RESERVEER-INFO === */
.contact-success {
    background: #f0faf0;
    border: 1px solid #a3d9a3;
    color: #1a5c1a;
    padding: 16px 20px;
    border-radius: var(--radius-sm);
    margin-bottom: 24px;
    font-size: 0.95rem;
}

.reserveer-info {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    background: rgba(178,34,52,0.05);
    border: 1px solid rgba(178,34,52,0.15);
    border-radius: var(--radius-sm);
    padding: 14px 18px;
    margin-bottom: 16px;
    animation: fadeSlideIn 0.4s ease;
}
.reserveer-info p {
    font-size: 0.88rem;
    color: var(--tekst-medium);
    line-height: 1.6;
    margin: 0;
}
@keyframes fadeSlideIn {
    from { opacity: 0; transform: translateY(-6px); }
    to { opacity: 1; transform: translateY(0); }
}

/* Page load animation */
body { animation: fadeInPage 1s ease-out; }
@keyframes fadeInPage {
    from { opacity: 0; transform: translateY(12px); }
    to { opacity: 1; transform: translateY(0); }
}

/* === 29. WOOCOMMERCE OVERRIDES === */
.woocommerce ul.products {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
    padding: 0;
    list-style: none;
}

.woocommerce ul.products li.product {
    background: var(--creme);
    border-radius: var(--radius);
    overflow: hidden;
    box-shadow: var(--schaduw-sm);
    transition: all var(--transitie);
    margin: 0 !important;
    width: 100% !important;
    float: none !important;
    padding: 0 !important;
    border: 1px solid rgba(44,24,16,0.05);
}

.woocommerce ul.products li.product:hover {
    box-shadow: var(--schaduw-warm);
}

.woocommerce ul.products li.product a img {
    width: 100%;
    height: 260px;
    object-fit: cover;
    border-radius: 0;
    margin: 0 !important;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
    font-family: 'Playfair Display', Georgia, serif !important;
    font-size: 1.1rem !important;
    padding: 16px 20px 4px !important;
    color: var(--tekst);
}

.woocommerce ul.products li.product .price {
    padding: 0 20px 12px;
    color: var(--rood) !important;
    font-weight: 600;
    font-size: 1.05rem !important;
}

.woocommerce ul.products li.product .price del {
    color: var(--tekst-licht) !important;
    font-weight: 400;
}

.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product .add_to_cart_button {
    display: block;
    margin: 0 20px 20px !important;
    background: var(--rood) !important;
    color: var(--creme) !important;
    border: none;
    padding: 12px 24px !important;
    border-radius: var(--radius-sm) !important;
    font-weight: 600;
    font-size: 0.9rem !important;
    text-align: center;
    transition: background var(--transitie);
    cursor: pointer;
    box-shadow: inset 0 -2px 0 rgba(0,0,0,0.15);
}

.woocommerce ul.products li.product .button:hover,
.woocommerce ul.products li.product .add_to_cart_button:hover {
    background: var(--donkerrood) !important;
}

.woocommerce .star-rating { color: var(--goud) !important; }

.woocommerce .onsale {
    background: var(--rood) !important;
    color: #fff !important;
    border-radius: var(--radius-sm) !important;
    font-weight: 600;
    padding: 4px 12px !important;
    min-height: auto !important;
    line-height: 1.6 !important;
}

.woocommerce div.product .product_title {
    font-family: 'Playfair Display', Georgia, serif !important;
    font-size: 2rem;
    color: var(--tekst);
}

.woocommerce div.product p.price {
    color: var(--rood) !important;
    font-size: 1.4rem !important;
    font-weight: 700;
}

.woocommerce div.product .single_add_to_cart_button {
    background: var(--rood) !important;
    border: none;
    border-radius: var(--radius-sm) !important;
    padding: 14px 32px !important;
    font-weight: 600;
    font-size: 1rem !important;
    transition: background var(--transitie);
    box-shadow: inset 0 -2px 0 rgba(0,0,0,0.15);
}

.woocommerce div.product .single_add_to_cart_button:hover {
    background: var(--donkerrood) !important;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
    color: var(--rood);
}

.woocommerce .cart_totals,
.woocommerce-cart table.cart {
    border-radius: var(--radius);
    overflow: hidden;
}

.woocommerce table.cart td.actions .coupon .input-text,
.woocommerce .checkout .form-row input.input-text,
.woocommerce .checkout .form-row textarea,
.woocommerce .checkout .form-row select {
    border: 2px solid rgba(44,24,16,0.10) !important;
    border-radius: var(--radius-sm) !important;
    padding: 10px 14px !important;
    transition: border-color var(--transitie);
}

.woocommerce .checkout .form-row input.input-text:focus,
.woocommerce .checkout .form-row textarea:focus {
    border-color: var(--rood) !important;
    outline: none;
}

.woocommerce #place_order,
.woocommerce .wc-proceed-to-checkout .checkout-button {
    background: var(--rood) !important;
    color: var(--creme) !important;
    border: none;
    border-radius: var(--radius-sm) !important;
    padding: 14px 32px !important;
    font-weight: 600;
    font-size: 1rem !important;
    transition: background var(--transitie);
    width: 100%;
    box-shadow: inset 0 -2px 0 rgba(0,0,0,0.15);
}

.woocommerce #place_order:hover,
.woocommerce .wc-proceed-to-checkout .checkout-button:hover {
    background: var(--donkerrood) !important;
}

.woocommerce .woocommerce-message {
    border-top-color: var(--rood) !important;
}

.woocommerce .woocommerce-message::before {
    color: var(--rood) !important;
}

@media (max-width: 900px) {
    .woocommerce ul.products { grid-template-columns: repeat(2, 1fr); gap: 20px; }
}
@media (max-width: 480px) {
    .woocommerce ul.products { grid-template-columns: 1fr; }
}

/* === 30. RESPONSIVE === */
@media (max-width: 1024px) {
    .footer-grid { grid-template-columns: 1fr 1fr; }
    .team-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 900px) {
    .grid-3, .review-grid { grid-template-columns: 1fr; gap: 20px; }
    .grid-2, .feature-row { grid-template-columns: 1fr; gap: 32px; }
    .contact-grid { grid-template-columns: 1fr; gap: 28px; }
    .stats-bar { grid-template-columns: repeat(2, 1fr); margin: -40px 24px 0; }
    .stat { border-bottom: 1px solid rgba(44,24,16,0.06); }
    section { padding: 56px 16px; }
    .team-grid { grid-template-columns: 1fr; }
    .menu-grid { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
    .menu-toggle { display: flex; align-items: center; justify-content: center; }
    .raaf-nav { display: none; }
    .header-cta { display: none; }
    .header-inner { padding: 0 16px; height: 58px; }

    .raaf-header {
        left: 10px;
        right: 10px;
        top: 8px;
    }

    .hero { min-height: 85vh; padding: 90px 16px 50px; }
    .hero h1 { font-size: 2rem; }
    .hero-subtitle { font-size: 1rem; margin-bottom: 24px; }
    .hero-badge { font-size: 0.72rem; padding: 6px 16px; margin-bottom: 20px; }

    section { padding: 48px 16px; }
    .section-header { margin-bottom: 32px; }
    .section-title { font-size: 1.6rem; }
    .section-subtitle { font-size: 0.9rem; }

    .stats-bar { grid-template-columns: 1fr 1fr; margin: -30px 16px 0; }
    .stat { padding: 20px 14px; }
    .stat-number { font-size: 1.4rem; }
    .stat-label { font-size: 0.72rem; }

    .kaart { padding: 24px 20px; }
    .kaart-icon { width: 48px; height: 48px; margin-bottom: 14px; }
    .kaart h3 { font-size: 1.05rem; }
    .kaart p { font-size: 0.88rem; }

    .form-row { grid-template-columns: 1fr; }
    .footer-grid { grid-template-columns: 1fr; gap: 28px; }
    .footer-top { padding: 60px 20px 36px; }

    .page-header { padding: 110px 16px 50px; }
    .page-header h1 { font-size: 1.8rem; }
    .page-header p { font-size: 0.95rem; }

    .contact-form { padding: 28px 20px; }
    .contact-form h3 { font-size: 1.2rem; margin-bottom: 20px; }
    .form-group input,
    .form-group textarea,
    .form-group select { padding: 12px 14px; font-size: 0.9rem; }
    .form-group label { font-size: 0.8rem; }

    .contact-icon { width: 40px; height: 40px; }
    .contact-icon svg { width: 18px; height: 18px; }
    .contact-info-kaart h4 { font-size: 0.72rem; }
    .contact-info-kaart p { font-size: 0.88rem; }

    .privacy-blok { padding: 20px; }
    .privacy-blok h3 { font-size: 1rem; }
    .privacy-blok p { font-size: 0.85rem; }

    .prijs-kaart { padding: 32px 24px; }
    .prijs-bedrag { font-size: 2rem; }

    .prijs-rij { padding: 18px 20px; }
    .prijs-groot { font-size: 1.15rem; }

    .voorwaarden-grid { grid-template-columns: 1fr; gap: 14px; }
    .voorwaarde-kaart { padding: 20px; }

    .map-container { height: 280px; }

    .review-kaart { padding: 24px 20px; }
    .review-tekst { font-size: 0.88rem; }

    .menu-kaart { padding: 24px 20px; }
    .menu-kaart h3 { font-size: 1.05rem; }
    .menu-kaart li { font-size: 0.88rem; }

    .raaf-cookie-notice { flex-direction: column; text-align: center; gap: 12px; padding: 14px 16px; }
    .raaf-cookie-notice p { font-size: 0.82rem; }

    .team-kaart { padding: 24px 16px; }
    .team-foto, .team-foto-placeholder { height: 200px; }
}

/* ========================================
   IPHONE-SPECIFIC MOBILE
   iPhone 14 Pro Max / 15 Plus / 15 Pro Max / 16 Pro Max (430px)
   iPhone 14 Pro / 15 / 15 Pro / 16 / 16 Pro (393px)
   iPhone X / XS / 11 Pro / 12 mini / 13 mini / SE3 (375px)
   ======================================== */

/* --- ALL PHONES: up to 430px (covers every iPhone) --- */
@media (max-width: 430px) {
    html { font-size: 15px; }

    .container { padding: 0 14px; max-width: 100vw; overflow-x: hidden; }

    /* Header */
    .raaf-header { left: 8px; right: 8px; top: 6px; border-radius: 12px; }
    .header-inner { padding: 0 14px; height: 54px; }
    .logo img { height: 32px; }
    .logo-text { font-size: 0.95rem; }
    .logo-text small { font-size: 0.5rem; letter-spacing: 2px; }
    .menu-toggle { width: 38px; height: 38px; }
	.menu-toggle span { left: 8.5px; width: 20px; }

    /* Announcement */
    .aankondiging-inner { padding: 8px 40px 8px 14px; font-size: 0.75rem; }

    /* Hero */
    .hero { min-height: 80vh; padding: 80px 14px 44px; }
    .hero-badge { font-size: 0.68rem; padding: 5px 14px; margin-bottom: 16px; letter-spacing: 1px; }
    .hero h1 { font-size: 1.7rem; margin-bottom: 14px; letter-spacing: -0.3px; }
    .hero h1 em { font-size: inherit; }
    .hero-subtitle { font-size: 0.9rem; margin-bottom: 20px; line-height: 1.65; }
    .hero-buttons { flex-direction: column; align-items: center; gap: 10px; }
    .btn { width: 100%; max-width: 100%; padding: 13px 24px; font-size: 0.8rem; letter-spacing: 0.5px; }
    .btn svg { width: 16px; height: 16px; }

    /* Sections */
    section { padding: 40px 14px; }
    .sectie-warmgrijs, .sectie-creme { padding: 40px 14px; }
    .section-header { margin-bottom: 24px; }
    .section-label { font-size: 0.68rem; letter-spacing: 2px; margin-bottom: 8px; }
    .section-title { font-size: 1.35rem; }
    .section-subtitle { font-size: 0.85rem; line-height: 1.65; }
    .accent-line { width: 36px; margin: 12px auto; }

    /* Cards */
    .kaart { padding: 22px 18px; border-radius: 14px; }
    .kaart-icon { width: 44px; height: 44px; margin-bottom: 12px; border-radius: 12px; }
    .kaart-icon svg { width: 20px; height: 20px; }
    .kaart h3 { font-size: 1rem; margin-bottom: 8px; }
    .kaart p { font-size: 0.84rem; line-height: 1.65; }
    .grid-3 { gap: 14px; }

    /* Feature Bar (home page) */
    .raaf-feature-bar { padding: 20px 0; }
    .feature-bar-inner { flex-direction: column; gap: 12px; align-items: flex-start; padding: 0 14px; }
    .feature-item { font-size: 0.88rem; gap: 10px; width: 100%; }
    .feature-item i { width: 18px; height: 18px; }

    /* Contact */
    .contact-grid { gap: 20px; }
    .contact-form { padding: 22px 16px; border-radius: 14px; }
    .contact-form h3 { font-size: 1.1rem; margin-bottom: 16px; }
    .form-group { margin-bottom: 14px; }
    .form-group label { font-size: 0.78rem; margin-bottom: 5px; }
    .form-group input,
    .form-group textarea,
    .form-group select { padding: 11px 12px; font-size: 0.88rem; border-radius: 8px; }
    .form-group textarea { height: 110px; }
    .form-row { gap: 12px; }
    .contact-info-kaart { flex-direction: column; text-align: center; align-items: center; gap: 10px; padding: 14px 0; }
    .contact-icon { width: 38px; height: 38px; border-radius: 10px; }
    .contact-icon svg { width: 16px; height: 16px; }
    .contact-info-kaart h4 { font-size: 0.7rem; }
    .contact-info-kaart p { font-size: 0.85rem; }
    .contact-success { padding: 12px 14px; font-size: 0.88rem; }
    .reserveer-info { padding: 12px 14px; }
    .reserveer-info p { font-size: 0.82rem; }

    /* Page Header (subpages) */
    .page-header { padding: 100px 14px 40px; }
    .page-header h1 { font-size: 1.5rem; margin-bottom: 8px; }
    .page-header p { font-size: 0.88rem; }

    /* Opening Hours */
    .uren-switcher { padding: 20px 16px; border-radius: 14px; }
    .uren-tabs-center { margin-bottom: 20px; }
    .uren-tab-pill { padding: 8px 18px; font-size: 0.8rem; }
    .uren-dag { min-width: 80px; font-size: 0.8rem; }
    .uren-lijn { margin: 0 10px; }
    .uren-tijd { font-size: 0.8rem; }
    .uren-rij { padding: 11px 0; }
    .uren-vandaag { padding: 11px 14px; margin: 0 -14px; }

    /* Footer */
    .footer-top { padding: 48px 14px 28px; }
    .footer-grid { gap: 24px; }
    .footer-desc { font-size: 0.82rem; }
    .footer-social a { width: 34px; height: 34px; border-radius: 8px; }
    .raaf-footer h4 { font-size: 0.78rem; margin-bottom: 16px; padding-bottom: 10px; }
    .footer-col ul a { font-size: 0.82rem; padding: 5px 0; }
    .footer-hours li { font-size: 0.78rem; padding: 4px 0; }
    .footer-contact-item { font-size: 0.82rem; gap: 8px; margin-bottom: 10px; }
    .footer-cta { font-size: 0.78rem; padding: 8px 18px; }
    .footer-bottom { padding: 14px 14px; }
    .footer-bottom-inner { font-size: 0.7rem; }

    /* Privacy */
    .privacy-blok { padding: 16px; gap: 10px; }
    .privacy-icon { width: 40px; height: 40px; }
    .privacy-blok h3 { font-size: 0.95rem; }
    .privacy-blok p { font-size: 0.82rem; }
    .privacy-blok ul li { font-size: 0.82rem; }

    /* Pricing */
    .prijs-kaart { padding: 28px 20px; }
    .prijs-bedrag { font-size: 1.8rem; }
    .prijs-label { font-size: 0.72rem; }
    .prijs-detail { font-size: 0.82rem; }
    .prijs-rij { padding: 16px; gap: 12px; flex-direction: column; text-align: center; }
    .prijs-groot { font-size: 1.1rem; }
    .prijs-rij-bedrag { text-align: center; }

    /* Reviews / Menu / Team */
    .review-kaart { padding: 20px 16px; border-radius: 14px; }
    .review-stars { font-size: 0.95rem; margin-bottom: 12px; }
    .review-tekst { font-size: 0.84rem; margin-bottom: 14px; }
    .review-auteur { font-size: 0.8rem; }
    .menu-kaart { padding: 22px 16px; border-radius: 14px; }
    .menu-kaart h3 { font-size: 1rem; margin-bottom: 12px; }
    .menu-kaart li { font-size: 0.84rem; padding: 6px 0; }
    .team-kaart { padding: 20px 14px; }
    .team-foto, .team-foto-placeholder { height: 180px; border-radius: 12px; }
    .team-info h3 { font-size: 1rem; }
    .team-info p { font-size: 0.82rem; }

    /* Map */
    .map-container { height: 240px; border-radius: 14px; }

    /* Cookie */
    .raaf-cookie-notice { padding: 12px 14px; gap: 10px; font-size: 0.8rem; }
    .raaf-cookie-notice button { padding: 8px 18px; font-size: 0.82rem; }

    /* Steps */
    .stap-nummer { width: 42px; height: 42px; font-size: 1.1rem; }

    /* Verhuur */
    .verhuur-categorie { padding: 28px 18px; }
    .verhuur-tag { font-size: 0.72rem; padding: 5px 12px; }
    .voorwaarde-kaart { padding: 18px; }
    .voorwaarde-icon { width: 38px; height: 38px; margin-bottom: 12px; }
    .voorwaarde-kaart h4 { font-size: 0.92rem; }
    .voorwaarde-kaart p { font-size: 0.82rem; }

    /* WooCommerce */
    .woocommerce ul.products { gap: 14px; }
    .woocommerce ul.products li.product a img { height: 200px; }
    .woocommerce ul.products li.product .woocommerce-loop-product__title { font-size: 0.95rem !important; padding: 12px 14px 4px !important; }
    .woocommerce ul.products li.product .price { padding: 0 14px 10px; font-size: 0.95rem !important; }
    .woocommerce ul.products li.product .button,
    .woocommerce ul.products li.product .add_to_cart_button { margin: 0 14px 14px !important; padding: 10px 20px !important; font-size: 0.82rem !important; }

    /* Back to top */
    .raaf-back-top { width: 40px; height: 40px; bottom: 20px; right: 16px; }

    /* Mobile menu adjustments */
    .mobile-menu { width: 280px; }
    .mobile-menu-header { padding: 14px 18px; }
    .mobile-nav a { padding: 12px 14px; font-size: 0.88rem; }
    .mobile-cta { padding: 12px; font-size: 0.85rem; }
}

/* --- SMALLER PHONES: iPhone X / XS / 11 Pro / 12 mini / 13 mini / SE (375px) --- */
@media (max-width: 375px) {
    html { font-size: 14px; }

    .container { padding: 0 12px; }

    .hero { padding: 74px 12px 36px; min-height: 75vh; }
    .hero-badge { font-size: 0.64rem; padding: 4px 12px; margin-bottom: 14px; }
    .hero h1 { font-size: 1.5rem; margin-bottom: 12px; }
    .hero-subtitle { font-size: 0.84rem; margin-bottom: 18px; }
    .btn { padding: 12px 20px; font-size: 0.78rem; }

    section { padding: 34px 12px; }
    .section-title { font-size: 1.2rem; }
    .section-subtitle { font-size: 0.82rem; }

    .kaart { padding: 18px 14px; }
    .kaart h3 { font-size: 0.92rem; }
    .kaart p { font-size: 0.8rem; }

    .contact-form { padding: 18px 14px; }
    .contact-form h3 { font-size: 1rem; }
    .form-group input,
    .form-group textarea,
    .form-group select { padding: 10px 10px; font-size: 0.84rem; }

    .page-header { padding: 90px 12px 34px; }
    .page-header h1 { font-size: 1.35rem; }
    .page-header p { font-size: 0.82rem; }

    .footer-top { padding: 40px 12px 24px; }
    .raaf-footer h4 { font-size: 0.72rem; }
    .footer-col ul a { font-size: 0.78rem; }

    .uren-switcher { padding: 16px 12px; }
    .uren-dag { min-width: 72px; font-size: 0.76rem; }
    .uren-tijd { font-size: 0.76rem; }
    .uren-tab-pill { padding: 7px 14px; font-size: 0.76rem; }

    .prijs-kaart { padding: 22px 16px; }
    .prijs-bedrag { font-size: 1.6rem; }

    .review-kaart { padding: 16px 14px; }
    .menu-kaart { padding: 18px 14px; }

    .mobile-menu { width: 260px; }
}

/* === HIDE ASTRA DEFAULTS === */
.ast-container, #primary, .entry-header, .ast-article-single,
.site-header, .main-header-bar, .site-footer,
.ast-footer-overlay, #ast-scroll-top { display: none !important; }
