/* ============== Ramenwasser Opleiding ============== */
:root{
  --cream:#FFF3DC;
  --cream-2:#FFE9BE;
  --paper:#FFFBF2;
  --ink:#0E2433;
  --ink-2:#1A3A52;
  --sky:#3FB4E5;
  --sky-deep:#1E7AB0;
  --sun:#FFC93C;
  --sun-2:#FFA01E;
  --coral:#FF6B57;
  --coral-2:#E64A36;
  --leaf:#3FAE6C;
  --shadow: 0 18px 40px -20px rgba(14,36,51,.35);
  --radius: 22px;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--cream);color:var(--ink);font-family:"DM Sans",system-ui,sans-serif;font-size:17px;line-height:1.55;-webkit-font-smoothing:antialiased}
body{overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;cursor:pointer;border:none;background:none}

/* Subtle paper texture */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;
  background-image:
    radial-gradient(rgba(14,36,51,.05) 1px, transparent 1px),
    radial-gradient(rgba(14,36,51,.04) 1px, transparent 1px);
  background-size: 3px 3px, 7px 7px;
  background-position: 0 0, 1px 2px;
  mix-blend-mode:multiply;opacity:.5;
}

.wrap{max-width:1200px;margin:0 auto;padding:0 28px}

/* ---------- Typography ---------- */
h1,h2,h3,h4{font-family:"Bricolage Grotesque",system-ui,sans-serif;font-weight:800;letter-spacing:-0.02em;line-height:1;color:var(--ink)}
.kicker{font-family:"JetBrains Mono",ui-monospace,monospace;font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--sky-deep)}
.mono{font-family:"JetBrains Mono",ui-monospace,monospace}

/* ---------- Nav ---------- */
.nav{position:sticky;top:0;z-index:50;backdrop-filter:blur(10px);background:rgba(255,243,220,.85);border-bottom:1px solid rgba(14,36,51,.08)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:18px 28px;max-width:1280px;margin:0 auto;gap:24px}
.nav-links{display:flex;gap:28px;font-weight:500;font-size:15px}
.nav-links a{position:relative;padding:6px 0}
.nav-links a:hover{color:var(--coral-2)}
.nav-cta{background:var(--ink);color:var(--paper);padding:11px 20px;border-radius:999px;font-weight:600;font-size:15px;transition:transform .15s ease,background .2s}
.nav-cta:hover{background:var(--coral-2);transform:translateY(-1px)}

/* ---------- Logo ---------- */
.logo{display:flex;align-items:center;gap:10px;font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:19px;letter-spacing:-0.02em;line-height:1}
.logo-mark{width:44px;height:44px;flex-shrink:0}
.logo small{display:block;font-family:"JetBrains Mono",monospace;font-weight:500;font-size:10px;letter-spacing:.18em;color:var(--sky-deep);text-transform:uppercase;margin-top:4px}

/* ---------- Hero ---------- */
.hero{position:relative;padding:64px 0 100px;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,.85fr);gap:56px;align-items:center}
.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;background:var(--sun);color:var(--ink);padding:8px 14px;border-radius:999px;font-family:"JetBrains Mono",monospace;font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;box-shadow: 0 6px 0 rgba(14,36,51,.12)}
.hero-eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--coral-2)}
.hero h1{font-size:clamp(48px,7.2vw,104px);margin:22px 0 24px;line-height:.95}
.hero h1 .accent{color:var(--coral-2);font-style:italic;font-weight:800}
.hero h1 .scribble{position:relative;display:inline-block}
.hero h1 .scribble::after{content:"";position:absolute;left:-4%;right:-4%;bottom:-2%;height:18px;background:var(--sun);z-index:-1;border-radius:6px;transform:rotate(-1deg)}
.hero p.lead{font-size:19px;color:var(--ink-2);max-width:540px;margin-bottom:32px}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.btn{display:inline-flex;align-items:center;gap:10px;padding:16px 26px;border-radius:999px;font-weight:600;font-size:16px;transition:transform .15s ease, box-shadow .2s}
.btn-primary{background:var(--coral);color:#fff;box-shadow:0 8px 0 var(--coral-2)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 0 var(--coral-2)}
.btn-primary:active{transform:translateY(4px);box-shadow:0 2px 0 var(--coral-2)}
.btn-ghost{background:transparent;color:var(--ink);border:2px solid var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}

.hero-meta{display:flex;gap:32px;margin-top:36px;flex-wrap:wrap}
.hero-meta div{display:flex;align-items:flex-start;gap:10px;font-size:14px;font-weight:500}
.hero-meta div svg{margin-top:3px;flex-shrink:0}
.hero-meta span{display:flex;flex-direction:column}
.hero-meta strong{font-family:"Bricolage Grotesque",sans-serif;font-size:22px;color:var(--coral-2);display:block;line-height:1;margin-bottom:2px}

/* Hero visual — dirty/clean window */
.hero-visual{position:relative;aspect-ratio:1/1.05;max-width:480px;margin-left:auto}
.hero-window{width:100%;height:100%;filter:drop-shadow(0 24px 40px rgba(14,36,51,.18))}

.hero-label{position:absolute;font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;padding:6px 11px;border-radius:999px;font-weight:600;z-index:5;pointer-events:none}
.hero-label-before{top:8%;left:4%;background:rgba(14,36,51,.85);color:#fff;transform:rotate(-3deg)}
.hero-label-after{bottom:14%;right:6%;background:var(--sun);color:var(--ink);transform:rotate(3deg);box-shadow:0 4px 0 var(--coral-2)}

/* Sticker badges around window */
.sticker{position:absolute;background:var(--paper);border-radius:999px;padding:10px 16px;font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:14px;box-shadow:0 8px 18px -10px rgba(14,36,51,.35);display:flex;align-items:center;gap:8px;z-index:6}
.sticker.s1{top:-14px;left:-22px;background:var(--sun);transform:rotate(-6deg)}
.sticker.s2{bottom:24px;right:-30px;background:var(--coral);color:#fff;transform:rotate(5deg)}
.sticker.s3{bottom:-18px;left:30px;background:var(--ink);color:var(--paper);transform:rotate(-3deg)}
.sticker svg{width:18px;height:18px}

/* (legacy hero sun/bubbles removed) */

/* ---------- Marquee ---------- */
.marquee{background:var(--ink);color:var(--paper);overflow:hidden;padding:18px 0;border-top:3px solid var(--coral);border-bottom:3px solid var(--coral)}
.marquee-track{display:flex;gap:60px;white-space:nowrap;animation:slide 30s linear infinite;font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:28px;letter-spacing:-0.02em}
.marquee-track span{display:inline-flex;align-items:center;gap:60px}
.marquee-track .star{color:var(--sun);font-size:24px}
@keyframes slide { from {transform:translateX(0)} to {transform:translateX(-50%)} }

/* ---------- Section base ---------- */
section.block{padding:110px 0;position:relative}
section.block h2{font-size:clamp(36px,5.4vw,72px);max-width:900px;margin-bottom:16px}
section.block h2 em{font-style:italic;color:var(--coral-2)}
.section-intro{max-width:640px;font-size:18px;color:var(--ink-2);margin-bottom:48px}

/* ---------- Programma ---------- */
.programma{background:var(--paper);position:relative;overflow:hidden}
.programma::before{content:"";position:absolute;top:-100px;right:-100px;width:300px;height:300px;border-radius:50%;background:var(--sun);opacity:.4;filter:blur(40px)}
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:22px;position:relative}
.card{background:var(--cream);border-radius:var(--radius);padding:28px;border:2px solid var(--ink);box-shadow:6px 6px 0 var(--ink);transition:transform .2s, box-shadow .2s;position:relative;overflow:hidden}
.card:hover{transform:translate(-2px,-2px);box-shadow:8px 8px 0 var(--ink)}
.card .num{font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--sky-deep);font-weight:600;letter-spacing:.1em}
.card h3{font-size:22px;margin:10px 0 12px;line-height:1.1}
.card p{font-size:15px;color:var(--ink-2);line-height:1.5}
.card-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.card:nth-child(1) .card-icon{background:var(--sky)}
.card:nth-child(2) .card-icon{background:var(--sun)}
.card:nth-child(3) .card-icon{background:var(--coral);color:#fff}
.card:nth-child(4) .card-icon{background:var(--leaf);color:#fff}
.card:nth-child(5) .card-icon{background:var(--sun-2)}
.card:nth-child(6) .card-icon{background:var(--sky-deep);color:#fff}
.card:nth-child(7) .card-icon{background:var(--coral);color:#fff}
.card:nth-child(8) .card-icon{background:var(--ink);color:var(--sun)}
.card-icon svg{width:26px;height:26px}

/* ---------- Inclusief / Prijs ---------- */
.includes{background:var(--ink);color:var(--paper);position:relative;overflow:hidden}
.includes::before{content:"";position:absolute;width:500px;height:500px;border-radius:50%;background:var(--coral);opacity:.18;filter:blur(80px);top:-200px;left:-100px}
.includes h2{color:var(--paper)}
.includes h2 em{color:var(--sun)}
.includes .section-intro{color:rgba(255,251,242,.7)}
.includes-grid{display:grid;grid-template-columns:1.4fr .8fr;gap:48px;align-items:start}
.includes-list{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.includes-item{display:flex;gap:14px;align-items:flex-start;padding:18px 20px;background:rgba(255,251,242,.06);border-radius:16px;border:1px solid rgba(255,251,242,.1)}
.includes-item svg{flex-shrink:0;width:24px;height:24px;color:var(--sun)}
.includes-item strong{display:block;font-family:"Bricolage Grotesque",sans-serif;font-size:17px;margin-bottom:4px}
.includes-item span{font-size:14px;color:rgba(255,251,242,.65);line-height:1.45}

.price-card{background:var(--sun);color:var(--ink);border-radius:24px;padding:32px;position:relative;box-shadow:8px 8px 0 var(--coral-2);transform:rotate(2deg)}
.price-card .kicker{color:var(--coral-2)}
.price-card .amount{font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:68px;line-height:1;margin:10px 0 6px;letter-spacing:-0.04em}
.price-card .amount sup{font-size:22px;vertical-align:top;margin-right:6px}
.price-card .vat{font-size:14px;color:var(--ink-2);margin-bottom:24px;font-weight:500}
.price-card .btn-primary{box-shadow:0 6px 0 var(--coral-2);width:100%;justify-content:center}
.price-card .group{margin-top:18px;font-size:14px;display:flex;align-items:center;gap:8px;color:var(--ink-2)}

/* ---------- Thomas ---------- */
.about{background:var(--cream-2);position:relative;overflow:hidden}
.about-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:64px;align-items:center}
.thomas-photo-wrap{position:relative;transform:rotate(-2deg)}
.thomas-photo{position:relative;aspect-ratio:3/4;border-radius:28px;overflow:hidden;border:14px solid var(--paper);box-shadow:var(--shadow)}
.thomas-photo img{width:100%;height:100%;object-fit:cover;object-position:center 30%}
.thomas-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg, transparent 60%, rgba(14,36,51,.15) 100%)}
.thomas-badge{position:absolute;bottom:-18px;right:-18px;background:var(--coral);color:#fff;padding:14px 18px;border-radius:18px;font-family:"Bricolage Grotesque",sans-serif;font-weight:700;font-size:15px;line-height:1.2;box-shadow:0 8px 18px -10px rgba(14,36,51,.4);transform:rotate(5deg);z-index:3}
.about p{margin-bottom:18px;font-size:17px;color:var(--ink-2)}
.about p:first-of-type::first-letter{font-family:"Bricolage Grotesque",sans-serif;font-size:64px;font-weight:800;float:left;line-height:.85;padding:6px 10px 0 0;color:var(--coral-2)}
.about .signature{margin-top:32px;display:flex;align-items:center;gap:14px}
.about .signature .sig-img{width:54px;height:54px;border-radius:50%;background:var(--ink);color:var(--sun);display:flex;align-items:center;justify-content:center;font-family:"Bricolage Grotesque",sans-serif;font-weight:800;font-size:20px}
.about .signature small{display:block;color:var(--ink-2);font-size:13px}
.about .signature strong{font-family:"Bricolage Grotesque",sans-serif;font-size:17px}

/* ---------- FAQ-ish facts ---------- */
.facts{padding:48px 0;background:var(--coral);color:#fff;border-top:3px solid var(--ink);border-bottom:3px solid var(--ink)}
.facts-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;text-align:left}
.fact strong{display:block;font-family:"Bricolage Grotesque",sans-serif;font-size:44px;line-height:1;margin-bottom:6px;letter-spacing:-0.02em}
.fact span{font-size:13px;text-transform:uppercase;letter-spacing:.1em;font-family:"JetBrains Mono",monospace;opacity:.85}

/* ---------- Signup form ---------- */
.signup{background:var(--paper)}
.signup-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.form-card{background:var(--cream);border:2px solid var(--ink);border-radius:24px;padding:36px;box-shadow:8px 8px 0 var(--ink)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.field{display:flex;flex-direction:column;gap:6px}
.field.full{grid-column:1/-1}
.field label{font-size:13px;font-weight:600;color:var(--ink);font-family:"JetBrains Mono",monospace;text-transform:uppercase;letter-spacing:.08em}
.field input,.field textarea,.field select{background:var(--paper);border:2px solid var(--ink);border-radius:12px;padding:13px 14px;font:inherit;color:var(--ink);transition:box-shadow .15s, transform .15s}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;box-shadow:4px 4px 0 var(--coral)}
.field textarea{min-height:100px;resize:vertical;font-family:inherit}
.submit-btn{margin-top:8px;width:100%;justify-content:center;font-size:17px;padding:18px}
.form-success{background:var(--leaf);color:#fff;padding:24px;border-radius:16px;display:none;margin-top:18px;font-weight:500}
.form-success.show{display:block}

.contact-side h3{font-size:clamp(28px,3.4vw,40px);margin-bottom:18px;line-height:1.05}
.contact-side p{color:var(--ink-2);margin-bottom:24px;font-size:17px}
.contact-info{display:flex;flex-direction:column;gap:14px;margin-top:24px}
.contact-info a{display:flex;align-items:center;gap:14px;padding:14px 18px;background:var(--cream);border:2px solid var(--ink);border-radius:14px;transition:transform .15s;font-weight:500}
.contact-info a:hover{transform:translateX(4px);background:var(--sun)}
.contact-info svg{width:22px;height:22px;color:var(--coral-2);flex-shrink:0}
.contact-info span{display:block}
.contact-info small{display:block;font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--ink-2);text-transform:uppercase;letter-spacing:.08em}

/* ---------- Footer ---------- */
footer{background:var(--ink);color:var(--paper);padding:60px 0 28px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:48px;margin-bottom:48px}
.footer-grid h4{font-size:15px;color:var(--sun);font-family:"JetBrains Mono",monospace;font-weight:600;text-transform:uppercase;letter-spacing:.1em;margin-bottom:18px}
.footer-grid p,.footer-grid a{color:rgba(255,251,242,.8);font-size:15px;line-height:1.7}
.footer-grid a:hover{color:var(--sun)}
.footer-grid ul{list-style:none;display:flex;flex-direction:column;gap:6px}
.footer-bottom{padding-top:28px;border-top:1px solid rgba(255,251,242,.15);display:flex;justify-content:space-between;align-items:center;font-size:13px;color:rgba(255,251,242,.6);font-family:"JetBrains Mono",monospace;flex-wrap:wrap;gap:12px}

/* ============== INTRO ANIMATION ============== */
.intro-overlay{position:fixed;inset:0;z-index:9999;pointer-events:none}
.intro-overlay .dirt{position:absolute;inset:0;background:linear-gradient(135deg, rgba(220,210,180,.45), rgba(180,200,210,.4) 60%, rgba(190,180,160,.55));mix-blend-mode:multiply;transition:opacity .3s ease}
.intro-overlay .dirt-svg{position:absolute;inset:0;width:100%;height:100%;opacity:.85;transition:opacity .3s ease}
.intro-overlay.cleaning .dirt,.intro-overlay.cleaning .dirt-svg{
  clip-path: var(--clip);
}
.intro-overlay.gone{opacity:0;transition:opacity .4s ease}
.squeegee{position:absolute;top:0;left:0;height:100%;z-index:10000;pointer-events:none;opacity:0}
.squeegee-img{height:100%;width:auto;display:block;transform:rotate(-90deg);transform-origin:center center;filter:drop-shadow(6px 0 20px rgba(0,0,0,.5))}

/* Skip button */
.skip-intro{position:fixed;bottom:24px;right:24px;z-index:10001;background:rgba(14,36,51,.85);color:var(--paper);padding:8px 14px;border-radius:999px;font-family:"JetBrains Mono",monospace;font-size:12px;letter-spacing:.08em;cursor:pointer;opacity:0;transition:opacity .3s;border:1px solid rgba(255,255,255,.15)}
.skip-intro.show{opacity:1}
.skip-intro:hover{background:var(--coral-2)}

/* ---------- Responsive ---------- */
@media (max-width: 1000px) {
  .hero{padding:36px 0 60px}
  .hero-grid{grid-template-columns:1fr;gap:36px}
  .hero-visual{margin:0 auto;max-width:380px}
  .nav-links{display:none}
  .includes-grid{grid-template-columns:1fr;gap:32px}
  .includes-list{grid-template-columns:1fr}
  .about-grid{grid-template-columns:1fr;gap:36px}
  .signup-grid{grid-template-columns:1fr;gap:36px}
  .footer-grid{grid-template-columns:1fr;gap:32px}
  .facts-grid{grid-template-columns:1fr 1fr;gap:24px}
  section.block{padding:64px 0}
  .marquee-track{font-size:22px}
}
@media (max-width: 540px) {
  .facts-grid{grid-template-columns:1fr 1fr}
  .form-row{grid-template-columns:1fr}
  .hero-meta{gap:18px}
  .price-card{transform:none}
}
