
    :root{
      --bg:#07080a;
      --bg2:#0d1114;
      --panel:#11161a;
      --panel2:#151d21;
      --ink:#f4efe7;
      --muted:#b9ada0;
      --soft:#d7c7b2;
      --line:rgba(244,239,231,.14);
      --red:#d91f26;
      --red2:#9d1418;
      --ao:#0f6670;
      --ao2:#82c7c8;
      --gold:#d6a85b;
      --shadow: 0 24px 80px rgba(0,0,0,.42);
      --radius: 26px;
      --max: 1180px;
    }
    *{box-sizing:border-box}
    html{scroll-behavior:smooth; width:100%; max-width:100%; overflow-x:hidden}
    body{
      margin:0;
      font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
      color:var(--ink);
      background:
        radial-gradient(circle at 18% 8%, rgba(217,31,38,.18), transparent 30%),
        radial-gradient(circle at 82% 18%, rgba(15,102,112,.18), transparent 34%),
        linear-gradient(180deg, #050607 0%, #0b0e10 44%, #08090b 100%);
      min-height:100vh;
      line-height:1.55;
      width:100%; max-width:100%; overflow-x:hidden;
    }
    body:before{
      content:"";
      position:fixed; inset:0; pointer-events:none; z-index:-1;
      opacity:.38;
      background-image:
        linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
      background-size:72px 72px;
      mask-image:radial-gradient(circle at center, black 0%, black 42%, transparent 82%);
    }
    a{color:inherit; text-decoration:none}
    img,svg{max-width:100%; height:auto}
    main, header, footer, section, .wrap, .hero-text, .hero-card, .panel, .card{min-width:0}
    .wrap{width:100%; max-width:var(--max); margin:0 auto; padding:0 24px}
    .eyebrow{
      display:inline-flex; align-items:center; gap:10px;
      color:var(--ao2); letter-spacing:.16em; text-transform:uppercase;
      font-size:.77rem; font-weight:800;
    }
    .eyebrow:before{content:""; width:32px; height:1px; background:var(--red)}
    h1,h2,h3,p{margin-top:0}
    h1{
      font-family: Georgia, "Times New Roman", serif;
      font-size:clamp(3.15rem, 8vw, 6.8rem);
      line-height:.9; letter-spacing:-.06em;
      margin:16px 0 26px;
      text-wrap:balance;
    }
    h2{
      font-family: Georgia, "Times New Roman", serif;
      font-size:clamp(2.1rem, 4.6vw, 4.6rem);
      line-height:.96; letter-spacing:-.045em;
      margin:12px 0 22px;
      text-wrap:balance;
    }
    h3{font-size:1.05rem; letter-spacing:.01em; margin:0 0 10px}
    .lead{font-size:clamp(1.09rem,2vw,1.35rem); color:#eee4d7; max-width:740px}
    .muted{color:var(--muted)}
    .small{font-size:.92rem; color:var(--muted)}
    .micro{font-size:.76rem; color:#9f948a; letter-spacing:.05em}
    .red{color:var(--red)}
    .ao{color:var(--ao2)}
    .gold{color:var(--gold)}
    .kanji{
      font-family: "Hiragino Mincho ProN", "Yu Mincho", "Noto Serif CJK JP", Georgia, serif;
      letter-spacing:.06em;
    }
    .btnrow{display:flex; flex-wrap:wrap; gap:14px; align-items:center; margin-top:28px}
    .btn{
      display:inline-flex; align-items:center; justify-content:center; gap:10px;
      min-height:48px; padding:13px 19px;
      border-radius:999px; border:1px solid rgba(244,239,231,.16);
      background:rgba(244,239,231,.07); color:var(--ink);
      font-weight:850; letter-spacing:.01em;
      box-shadow: 0 10px 35px rgba(0,0,0,.24);
      transition:.22s ease;
      cursor:pointer;
    }
    .btn:hover{transform:translateY(-2px); background:rgba(244,239,231,.12); border-color:rgba(244,239,231,.28)}
    .btn.primary{background:linear-gradient(135deg,var(--red),var(--red2)); border-color:rgba(217,31,38,.8); color:white}
    .btn.primary:hover{filter:brightness(1.08)}
    .btn.ghost{background:transparent}
    .btn.dark{background:rgba(0,0,0,.26)}
    .tag{
      display:inline-flex; align-items:center; gap:8px;
      padding:8px 11px; border-radius:999px;
      background:rgba(244,239,231,.07);
      border:1px solid var(--line); color:#e8ddd1;
      font-size:.82rem; font-weight:760;
      white-space:nowrap;
    }
    .tag .dot{width:7px; height:7px; border-radius:50%; background:var(--red); box-shadow:0 0 18px rgba(217,31,38,.8)}

    .topnote{
      background:linear-gradient(90deg, rgba(15,102,112,.36), rgba(217,31,38,.22));
      border-bottom:1px solid var(--line);
      color:#f5eee6;
      font-size:.82rem;
      padding:8px 0;
    }
    .topnote .wrap{display:flex; justify-content:space-between; gap:16px; align-items:center}
    .toggle-notes{
      all:unset; cursor:pointer; color:#fff; font-weight:800; opacity:.9;
    }
    header{
      position:sticky; top:0; z-index:40;
      backdrop-filter:blur(18px);
      background:rgba(7,8,10,.73);
      border-bottom:1px solid var(--line);
    }
    .nav{height:78px; display:flex; align-items:center; justify-content:space-between; gap:18px}
    .brand{display:flex; align-items:center; gap:12px; min-width:230px}
    .brand img{
      width:48px; height:48px; object-fit:cover; border-radius:50%;
      border:1px solid rgba(244,239,231,.18); background:white;
      box-shadow:0 10px 30px rgba(0,0,0,.35)
    }
    .brand strong{display:block; font-size:1.03rem; letter-spacing:.08em}
    .brand span{display:block; font-size:.7rem; color:var(--muted); letter-spacing:.14em; text-transform:uppercase}
    nav ul{display:flex; list-style:none; margin:0; padding:0; gap:2px; align-items:center}
    nav a{display:block; padding:10px 11px; border-radius:999px; color:#ded3c8; font-size:.89rem; font-weight:720}
    nav a:hover{background:rgba(244,239,231,.08); color:white}
    .mobilebtn{display:none}

    .hero{position:relative; padding:84px 0 70px}
    .hero:after{
      content:"青鷹道場";
      position:absolute; right:-28px; top:70px;
      writing-mode:vertical-rl;
      font-family:"Hiragino Mincho ProN", "Yu Mincho", Georgia, serif;
      color:rgba(244,239,231,.055); font-size:7.5rem; letter-spacing:.05em; pointer-events:none;
    }
    .hero-grid{display:grid; grid-template-columns:1.04fr .96fr; gap:42px; align-items:center}
    .hero-text{position:relative; z-index:2}
    .hero .lead{font-size:clamp(1.15rem,2.2vw,1.48rem)}
    .hero-tags{display:flex; flex-wrap:wrap; gap:9px; margin:28px 0 0}
    .signature{
      margin-top:30px; display:grid; grid-template-columns:70px 1fr; gap:18px; align-items:center;
      max-width:560px; color:var(--soft);
    }
    .seal{
      width:64px; height:64px; border:2px solid var(--red); color:var(--red);
      display:grid; place-items:center; border-radius:50%;
      font-family:"Hiragino Mincho ProN", "Yu Mincho", Georgia, serif;
      font-size:1.2rem; line-height:1.1;
      box-shadow:0 0 40px rgba(217,31,38,.15) inset;
    }
    .hero-card{
      position:relative; min-height:600px; border-radius:42px; overflow:hidden;
      border:1px solid rgba(244,239,231,.13); box-shadow:var(--shadow);
      background:#111;
      isolation:isolate;
    }
    .hero-card:before{
      content:""; position:absolute; inset:0; z-index:-3;
      background:
        linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,.62)),
        radial-gradient(circle at 57% 32%, rgba(217,31,38,.9) 0 16%, transparent 17%),
        linear-gradient(110deg, #111 0%, #1d211f 35%, #0b0b0c 100%);
    }
    .hero-card:after{
      content:""; position:absolute; inset:0; z-index:-2; opacity:.75;
      background:
        linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px),
        linear-gradient(180deg, rgba(255,255,255,.045) 1px, transparent 1px);
      background-size:42px 42px;
      mask-image:linear-gradient(180deg, transparent, black 18%, black 72%, transparent);
    }
    .dojo-floor{
      position:absolute; left:0; right:0; bottom:0; height:42%; z-index:-1;
      background:
        linear-gradient(180deg, transparent, rgba(0,0,0,.72)),
        repeating-linear-gradient(178deg, rgba(214,168,91,.11) 0 2px, transparent 2px 34px),
        linear-gradient(155deg, rgba(77,50,27,.4), rgba(0,0,0,.55));
      transform:skewY(-4deg); transform-origin:right top;
    }
    .hero-svg{position:absolute; inset:auto 3% 12% auto; width:84%; max-width:520px; opacity:.98; filter:drop-shadow(0 26px 34px rgba(0,0,0,.55))}
    .photo-label{
      position:absolute; left:22px; bottom:22px; right:22px;
      padding:14px 16px; border-radius:20px; border:1px solid rgba(244,239,231,.13);
      background:rgba(0,0,0,.47); backdrop-filter:blur(12px);
      color:#e8ded2;
      font-size:.88rem;
      display:none;
    }
    body.notes-on .photo-label{display:block}
    .hero-side-note{
      position:absolute; top:22px; right:22px; max-width:250px;
      border:1px solid rgba(244,239,231,.13); border-radius:20px;
      padding:14px; background:rgba(0,0,0,.38); backdrop-filter:blur(14px);
    }
    .hero-side-note strong{display:block; color:white; margin-bottom:4px}
    .hero-side-note span{font-size:.82rem; color:var(--muted)}

    section{padding:86px 0; position:relative}
    .section-head{display:flex; align-items:end; justify-content:space-between; gap:24px; margin-bottom:34px}
    .section-head p{max-width:610px; margin-bottom:4px; color:var(--muted)}
    .panel{
      border:1px solid var(--line); background:linear-gradient(180deg, rgba(244,239,231,.075), rgba(244,239,231,.035));
      border-radius:var(--radius); padding:28px; box-shadow:0 18px 60px rgba(0,0,0,.22);
    }
    .panel.dark{background:linear-gradient(180deg, rgba(0,0,0,.25), rgba(244,239,231,.035))}
    .grid3{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
    .grid4{display:grid; grid-template-columns:repeat(4,1fr); gap:18px}
    .grid2{display:grid; grid-template-columns:repeat(2,1fr); gap:22px}
    .card{
      border:1px solid var(--line); border-radius:24px; padding:24px;
      background:linear-gradient(180deg, rgba(255,255,255,.065), rgba(255,255,255,.028));
      min-height:100%; position:relative; overflow:hidden;
    }
    .card:before{
      content:""; position:absolute; inset:0; pointer-events:none;
      background:radial-gradient(circle at top right, rgba(217,31,38,.1), transparent 38%);
      opacity:.8;
    }
    .card > *{position:relative}
    .card h3{font-size:1.18rem}
    .card p{color:var(--muted); margin-bottom:0}
    .num{
      font-family:Georgia,serif; font-size:2.4rem; color:rgba(244,239,231,.18);
      line-height:1; margin-bottom:18px;
    }
    .intro-band{
      padding:26px 0; border-block:1px solid var(--line);
      background:linear-gradient(90deg, rgba(217,31,38,.10), rgba(15,102,112,.10));
    }
    .intro-band .wrap{display:grid; grid-template-columns:1.2fr .8fr; gap:28px; align-items:center}
    .intro-band h2{font-size:clamp(1.7rem,3.2vw,3rem); margin-bottom:8px}
    .statrow{display:grid; grid-template-columns:repeat(3,1fr); gap:10px}
    .stat{padding:16px; border:1px solid var(--line); border-radius:19px; background:rgba(0,0,0,.18)}
    .stat strong{display:block; font-size:1.15rem}
    .stat span{display:block; font-size:.82rem; color:var(--muted)}

    .karate-meaning{display:grid; grid-template-columns:.9fr 1.1fr; gap:24px; align-items:stretch}
    .meaning-card{
      position:relative; overflow:hidden; min-height:420px; border-radius:34px; border:1px solid var(--line);
      background:
        radial-gradient(circle at 50% 36%, rgba(217,31,38,.8) 0 17%, transparent 18%),
        linear-gradient(140deg, rgba(255,255,255,.08), rgba(255,255,255,.02)),
        #101316;
      box-shadow:var(--shadow);
    }
    .meaning-card:before{content:"空手道"; position:absolute; inset:22px auto auto 26px; font-family:"Hiragino Mincho ProN","Yu Mincho",Georgia,serif; font-size:4.8rem; color:rgba(244,239,231,.18); writing-mode:vertical-rl; line-height:1}
    .meaning-card:after{content:""; position:absolute; left:0; right:0; bottom:0; height:42%; background:linear-gradient(180deg, transparent, rgba(0,0,0,.78)), repeating-linear-gradient(178deg, rgba(244,239,231,.08) 0 2px, transparent 2px 26px)}
    .impact-note{margin-top:18px; padding:14px 16px; border-left:3px solid var(--red); border-radius:14px; background:rgba(185,28,28,.14); color:rgba(255,255,255,.9); font-size:.98rem; line-height:1.55}
    .meaning-content{position:absolute; left:26px; right:26px; bottom:24px; z-index:2}
    .pillars{display:grid; gap:14px}
    .pillar{display:grid; grid-template-columns:52px 1fr; gap:15px; align-items:start; padding:18px; border-radius:22px; border:1px solid var(--line); background:rgba(244,239,231,.045)}
    .icon{width:52px; height:52px; border-radius:18px; display:grid; place-items:center; border:1px solid rgba(244,239,231,.14); background:rgba(0,0,0,.22); color:var(--ao2); font-weight:900}

    .program-tabs{display:flex; gap:10px; flex-wrap:wrap; margin-bottom:20px}
    .tab{
      border:1px solid var(--line); color:var(--soft); background:rgba(255,255,255,.045);
      padding:10px 14px; border-radius:999px; cursor:pointer; font-weight:780;
    }
    .tab.active{background:linear-gradient(135deg, var(--red), var(--red2)); color:white; border-color:rgba(217,31,38,.75)}
    .program-grid{display:grid; grid-template-columns:.95fr 1.05fr; gap:22px; align-items:stretch}
    .program-list{display:grid; gap:12px}
    .program-card{
      text-align:left; color:var(--ink); cursor:pointer; border:1px solid var(--line); border-radius:24px;
      padding:18px; background:rgba(255,255,255,.045); width:100%; transition:.2s;
    }
    .program-card:hover,.program-card.active{background:rgba(255,255,255,.09); border-color:rgba(130,199,200,.38); transform:translateY(-1px)}
    .program-card .age{display:block; color:var(--ao2); font-size:.8rem; letter-spacing:.1em; text-transform:uppercase; font-weight:850}
    .program-detail{min-height:520px; position:relative; overflow:hidden}
    .program-detail:before{content:""; position:absolute; inset:0; background:radial-gradient(circle at 70% 18%, rgba(15,102,112,.18), transparent 34%), radial-gradient(circle at 18% 18%, rgba(217,31,38,.14), transparent 30%); pointer-events:none}
    .program-detail > *{position:relative}
    .checklist{list-style:none; padding:0; margin:18px 0 0; display:grid; gap:10px}
    .checklist li{display:grid; grid-template-columns:24px 1fr; gap:10px; color:#e6dbcf}
    .checklist li:before{content:""; width:18px; height:18px; margin-top:4px; border-radius:50%; border:1px solid rgba(130,199,200,.5); background:radial-gradient(circle,var(--ao2) 0 3px, transparent 4px)}

    .timeline{display:grid; grid-template-columns:repeat(5,1fr); gap:12px; position:relative}
    .step{padding:20px; border:1px solid var(--line); border-radius:22px; background:rgba(255,255,255,.045)}
    .step strong{display:block; margin-bottom:8px}
    .step span{display:block; color:var(--muted); font-size:.9rem}

    .dojo-layout{display:grid; grid-template-columns:1.05fr .95fr; gap:24px}
    .schedule{display:grid; gap:12px}
    .time-card{display:grid; grid-template-columns:96px 1fr 110px; gap:14px; align-items:center; padding:16px; border:1px solid var(--line); border-radius:20px; background:rgba(0,0,0,.18)}
    .time-card .day{font-weight:900; color:white}
    .time-card .group{font-weight:850}
    .time-card .small, .time-card span{display:block}
    .time-card .time{text-align:right; color:var(--ao2); font-weight:900}
    .location-card{min-height:100%; display:flex; flex-direction:column; justify-content:space-between; gap:20px}
    .mapbox{height:220px; border:1px solid var(--line); border-radius:24px; overflow:hidden; position:relative; background:linear-gradient(145deg, rgba(15,102,112,.24), rgba(217,31,38,.12)), #111}
    .mapbox:before{content:""; position:absolute; inset:0; background-image:linear-gradient(90deg, rgba(255,255,255,.09) 1px, transparent 1px), linear-gradient(rgba(255,255,255,.07) 1px, transparent 1px); background-size:38px 38px; opacity:.45}
    .map-pin{position:absolute; left:52%; top:44%; transform:translate(-50%,-50%); width:58px; height:58px; border-radius:50% 50% 50% 0; background:var(--red); rotate:-45deg; box-shadow:0 12px 34px rgba(0,0,0,.45)}
    .map-pin:after{content:""; position:absolute; width:20px; height:20px; border-radius:50%; background:#101316; left:19px; top:19px}
    .mapbox span{position:absolute; left:18px; bottom:14px; right:18px; font-size:.88rem; color:#eee; padding:11px 13px; background:rgba(0,0,0,.44); border-radius:15px; border:1px solid var(--line)}

    .activity-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
    .activity{min-height:260px; display:flex; flex-direction:column; justify-content:flex-end; position:relative; overflow:hidden; border-radius:28px; border:1px solid var(--line); padding:22px; background:#111; box-shadow:0 18px 60px rgba(0,0,0,.22)}
    .activity:before{content:""; position:absolute; inset:0; background:linear-gradient(180deg, transparent 25%, rgba(0,0,0,.82) 100%), radial-gradient(circle at 68% 24%, rgba(217,31,38,.34), transparent 27%), linear-gradient(135deg, rgba(255,255,255,.08), rgba(255,255,255,.02)); opacity:1}
    .activity:after{content:""; position:absolute; inset:0; background-size:54px 54px; background-image:linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px), linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px); mask-image:linear-gradient(180deg, black, transparent 62%); opacity:.5}
    .activity > *{position:relative; z-index:2}
    .activity .month{display:inline-flex; align-self:flex-start; padding:6px 9px; border-radius:999px; background:rgba(217,31,38,.82); font-size:.78rem; font-weight:900; margin-bottom:10px}
    .activity p{color:#c9beb3; margin-bottom:0}

    .photo-grid{display:grid; grid-template-columns:1.2fr .8fr .8fr; grid-template-rows:220px 220px; gap:14px}
    .photo{position:relative; border-radius:28px; overflow:hidden; border:1px solid var(--line); background:#111; box-shadow:0 18px 54px rgba(0,0,0,.22)}
    .photo.big{grid-row:span 2}
    .photo:before{content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(0,0,0,.05), rgba(0,0,0,.72)), var(--bgimg, radial-gradient(circle at 55% 35%, rgba(217,31,38,.35), transparent 24%), linear-gradient(135deg, rgba(255,255,255,.08), rgba(255,255,255,.02)))}
    .photo:after{content:attr(data-title); position:absolute; left:15px; right:15px; bottom:15px; padding:10px 12px; border-radius:15px; background:rgba(0,0,0,.46); border:1px solid rgba(244,239,231,.12); color:#fff; font-size:.86rem; display:none}
    body.notes-on .photo:after{display:block}
    .p1{--bgimg:radial-gradient(circle at 52% 28%, rgba(217,31,38,.42), transparent 22%), linear-gradient(140deg, #222, #060606 70%)}
    .p2{--bgimg:radial-gradient(circle at 40% 45%, rgba(130,199,200,.35), transparent 28%), repeating-linear-gradient(12deg, rgba(255,255,255,.08) 0 4px, transparent 4px 16px), #111}
    .p3{--bgimg:radial-gradient(circle at 48% 30%, rgba(214,168,91,.28), transparent 24%), linear-gradient(145deg, #151515, #080808)}
    .p4{--bgimg:radial-gradient(circle at 64% 50%, rgba(15,102,112,.42), transparent 28%), linear-gradient(135deg, #171e20, #060707)}
    .p5{--bgimg:radial-gradient(circle at 50% 58%, rgba(217,31,38,.3), transparent 21%), linear-gradient(145deg, #202020, #060606)}

    .first-lesson{display:grid; grid-template-columns:.9fr 1.1fr; gap:24px; align-items:start}
    .steps{counter-reset:steps; display:grid; gap:12px}
    .lesson-step{counter-increment:steps; display:grid; grid-template-columns:58px 1fr; gap:16px; padding:18px; border-radius:22px; border:1px solid var(--line); background:rgba(0,0,0,.18)}
    .lesson-step:before{content:counter(steps); width:52px; height:52px; border-radius:50%; display:grid; place-items:center; background:rgba(217,31,38,.9); font-family:Georgia,serif; font-size:1.55rem; font-weight:800}

    .juku-block{display:grid; grid-template-columns:1fr .85fr; gap:24px; align-items:center; border-radius:38px; overflow:hidden; border:1px solid var(--line); background:linear-gradient(135deg, rgba(15,102,112,.18), rgba(217,31,38,.08)), rgba(255,255,255,.045); padding:34px}
    .bookstack{border:1px solid var(--line); border-radius:30px; background:rgba(0,0,0,.24); padding:22px; min-height:320px; position:relative; overflow:hidden}
    .bookstack:before{content:""; position:absolute; inset:0; background:radial-gradient(circle at 72% 28%, rgba(217,31,38,.16), transparent 30%); pointer-events:none}
    .book{position:relative; display:grid; grid-template-columns:54px 1fr; gap:14px; padding:14px; border-radius:18px; border:1px solid var(--line); background:rgba(255,255,255,.045); margin-bottom:12px}
    .bookicon{width:54px; height:54px; border-radius:14px; background:linear-gradient(135deg, var(--ao), #0a3137); display:grid; place-items:center; font-weight:900}

    .instructor{display:grid; grid-template-columns:.86fr 1.14fr; gap:24px; align-items:stretch}
    .instructor-art{min-height:520px; border-radius:34px; border:1px solid var(--line); overflow:hidden; position:relative; background:linear-gradient(160deg, rgba(255,255,255,.06), rgba(0,0,0,.25)), #111; box-shadow:var(--shadow)}
    .instructor-art:before{content:""; position:absolute; inset:0; background:radial-gradient(circle at 54% 24%, rgba(217,31,38,.38), transparent 23%), linear-gradient(180deg, transparent 35%, rgba(0,0,0,.75)), repeating-linear-gradient(177deg, rgba(255,255,255,.055) 0 2px, transparent 2px 30px)}
    .instructor-art:after{content:"Beeldrichting: instructeur begeleidt leerling / detail van uitleg, niet poserend als heldenfoto"; position:absolute; left:18px; right:18px; bottom:18px; border:1px solid var(--line); padding:13px 14px; border-radius:18px; background:rgba(0,0,0,.46); display:none; color:#e8ded2; font-size:.86rem}
    body.notes-on .instructor-art:after{display:block}

    .faq{display:grid; gap:12px}
    details{border:1px solid var(--line); border-radius:20px; background:rgba(255,255,255,.045); padding:0 18px}
    summary{cursor:pointer; padding:18px 0; font-weight:850; color:#fff}
    details p{padding:0 0 18px; color:var(--muted); margin:0}

    form{display:grid; gap:12px}
    label{display:grid; gap:7px; color:#e5dacf; font-weight:760; font-size:.92rem}
    input,select,textarea{
      width:100%; border:1px solid rgba(244,239,231,.17); border-radius:16px; padding:13px 14px;
      background:rgba(0,0,0,.28); color:var(--ink); font:inherit; outline:none;
    }
    input:focus,select:focus,textarea:focus{border-color:rgba(130,199,200,.62); box-shadow:0 0 0 3px rgba(130,199,200,.12)}
    textarea{min-height:110px; resize:vertical}
    .form-grid{display:grid; grid-template-columns:1fr 1fr; gap:12px}
    .form-note{display:none; border:1px solid rgba(130,199,200,.35); background:rgba(15,102,112,.18); padding:12px 14px; border-radius:16px; color:#e8ffff}

    .final-cta{padding:92px 0 106px}
    .cta-box{position:relative; overflow:hidden; border-radius:42px; border:1px solid var(--line); padding:46px; background:linear-gradient(135deg, rgba(217,31,38,.2), rgba(15,102,112,.2)), rgba(255,255,255,.06); box-shadow:var(--shadow)}
    .cta-box:before{content:"心"; position:absolute; right:42px; bottom:-34px; font-family:"Hiragino Mincho ProN", "Yu Mincho", Georgia, serif; font-size:14rem; color:rgba(244,239,231,.055); line-height:1}
    .cta-box > *{position:relative}

    footer{border-top:1px solid var(--line); padding:34px 0; background:rgba(0,0,0,.24)}
    .footer-grid{display:grid; grid-template-columns:1.2fr .8fr .8fr; gap:24px}
    .footer-logo{display:flex; gap:12px; align-items:center; margin-bottom:12px}
    .footer-logo img{width:44px; height:44px; border-radius:50%; background:white; object-fit:cover}
    .footer-list{list-style:none; padding:0; margin:0; display:grid; gap:8px; color:var(--muted); font-size:.92rem}

    .dev-notes{padding:34px 0 70px; background:rgba(0,0,0,.18)}
    .dev-notes details{background:rgba(0,0,0,.2)}
    .dev-notes code{color:#f7e4c0}

    @media (max-width: 980px){
      .hero-grid,.karate-meaning,.program-grid,.dojo-layout,.first-lesson,.juku-block,.instructor,.intro-band .wrap{grid-template-columns:1fr}
      .hero-card{min-height:520px}
      .grid3,.grid4,.activity-grid{grid-template-columns:1fr 1fr}
      .timeline{grid-template-columns:1fr 1fr}
      .section-head{display:block}
      nav ul{display:none; position:absolute; left:16px; right:16px; top:78px; background:rgba(7,8,10,.96); border:1px solid var(--line); border-radius:24px; padding:12px; box-shadow:var(--shadow)}
      nav ul.open{display:grid}
      nav a{padding:12px 14px}
      .mobilebtn{display:inline-flex}
      .brand{min-width:auto}
      .brand span{display:none}
      .photo-grid{grid-template-columns:1fr 1fr; grid-template-rows:200px 200px 200px}
      .photo.big{grid-row:span 1; grid-column:span 2}
    }
    @media (max-width: 640px){
      body{overflow-x:hidden}
      .wrap{padding:0 16px}
      .topnote{display:none}
      .nav{height:66px; gap:10px}
      .brand img{width:42px; height:42px}
      nav ul{top:66px; left:10px; right:10px; max-width:calc(100vw - 20px)}
      .mobilebtn{min-height:44px; padding:10px 16px}
      .hero{padding:48px 0 48px}
      .hero:after{display:none}
      .hero-grid{gap:28px}
      .hero-card{min-height:390px; border-radius:28px}
      .hero-side-note{left:16px; right:16px; max-width:none}
      .hero-svg{width:96%; right:-4%; bottom:8%}
      .hero .lead{font-size:1.02rem; line-height:1.62}
      .btnrow{gap:10px; margin-top:24px}
      .btn{max-width:100%; padding:12px 16px; min-height:46px}
      .tag{white-space:normal; max-width:100%}
      .signature{grid-template-columns:56px 1fr; gap:14px}
      .seal{width:54px; height:54px; font-size:1rem}
      section{padding:58px 0}
      .grid3,.grid4,.grid2,.activity-grid,.timeline,.statrow{grid-template-columns:1fr}
      .time-card{grid-template-columns:1fr; gap:5px}
      .time-card .time{text-align:left}
      .photo-grid{grid-template-columns:1fr; grid-template-rows:repeat(5,190px)}
      .photo.big{grid-column:auto}
      .form-grid{grid-template-columns:1fr}
      .footer-grid{grid-template-columns:1fr}
      .cta-box{padding:28px}
      .juku-block{padding:22px}
      h1{font-size:clamp(2.6rem, 12.2vw, 3.65rem); line-height:.95; letter-spacing:-.052em; overflow-wrap:normal; hyphens:none}
      h2{font-size:clamp(2rem, 10vw, 3.05rem)}
    }
    @media (max-width: 390px){
      h1{font-size:clamp(2.35rem, 11.6vw, 3.15rem)}
      .wrap{padding:0 14px}
      .eyebrow{font-size:.68rem; letter-spacing:.12em; gap:8px}
      .eyebrow:before{width:24px}
    }
  

/* WordPress basis-correcties */
.admin-bar header{top:32px}
@media (max-width:782px){.admin-bar header{top:46px}}


/* Stap 3: publieke SEO/accessibility-afwerking */
.skip-link{
  position:absolute;
  left:-999px;
  top:12px;
  z-index:9999;
  background:#fff;
  color:#111;
  padding:10px 14px;
  border-radius:10px;
  font-weight:800;
}
.skip-link:focus{left:12px}
body{overflow-x:hidden}


/* Stap 4: basis voor echte WordPress-pagina's */
.page-main{background:radial-gradient(circle at 20% 0%, rgba(95,12,18,.42), transparent 34%), var(--bg); min-height:70vh}
.page-hero{padding:86px 0 44px; border-bottom:1px solid var(--line); position:relative; overflow:hidden}
.page-hero:after{content:"道"; position:absolute; right:5vw; top:10px; font-family:"Hiragino Mincho ProN","Yu Mincho",Georgia,serif; font-size:18rem; line-height:1; color:rgba(244,239,231,.035); pointer-events:none}
.page-hero-grid{display:grid; grid-template-columns:minmax(0,1fr) 210px; gap:32px; align-items:center; position:relative; z-index:1}
.page-hero h1{max-width:980px}
.page-mark{width:160px; height:160px; border-radius:50%; display:grid; place-items:center; border:1px solid rgba(217,31,38,.55); background:radial-gradient(circle, rgba(217,31,38,.28), rgba(0,0,0,.22)); color:#ffdddd; font-family:"Hiragino Mincho ProN","Yu Mincho",serif; font-size:2.4rem; box-shadow:var(--shadow)}
.page-content-section{padding:58px 0 92px}
.page-content{display:grid; gap:24px}
.page-grid{display:grid; grid-template-columns:1.15fr .85fr; gap:24px; align-items:start}
.content-card{border:1px solid var(--line); border-radius:30px; padding:28px; background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.025)); box-shadow:0 18px 60px rgba(0,0,0,.22)}
.content-card.dark{background:linear-gradient(180deg, rgba(0,0,0,.32), rgba(255,255,255,.025))}
.content-card h2{margin-top:10px}
.content-card p:last-child{margin-bottom:0}
.page-cards{margin-top:0}
.page-time{display:grid; gap:12px}
.page-content a:not(.btn){color:#b9fbff; text-decoration:none; border-bottom:1px solid rgba(185,251,255,.25)}
.page-content a:not(.btn):hover{border-color:rgba(185,251,255,.7)}
@media (max-width:980px){.page-hero-grid,.page-grid{grid-template-columns:1fr}.page-mark{width:110px;height:110px;font-size:1.7rem}.page-hero:after{font-size:12rem;right:-20px}}
@media (max-width:640px){.page-hero{padding:58px 0 34px}.page-content-section{padding:38px 0 66px}.content-card{padding:22px;border-radius:24px}.page-mark{display:none}.page-hero h1{font-size:clamp(2.25rem, 11vw, 3.3rem)}}

/* Stap 5: werkend proeflesformulier */
.proefles-form-card{margin-top:8px}
.aotaka-form{margin-top:20px}
.form-message{border-radius:18px; padding:14px 16px; margin:14px 0 18px; font-weight:760; line-height:1.5}
.form-message.success{border:1px solid rgba(130,199,200,.48); background:rgba(15,102,112,.22); color:#e8ffff}
.form-message.error{border:1px solid rgba(217,31,38,.55); background:rgba(217,31,38,.16); color:#fff0f0}
.hp-field{position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden}
.consent-row{display:grid; grid-template-columns:22px 1fr; gap:12px; align-items:start; color:var(--muted); font-weight:650; font-size:.9rem; line-height:1.5}
.consent-row input{width:18px; height:18px; margin-top:3px; accent-color:var(--red)}
.form-actions{display:flex; gap:16px; align-items:center; flex-wrap:wrap; margin-top:4px}
.form-actions .small{margin:0; max-width:520px}
@media (max-width:640px){.form-actions{display:grid}.form-actions .btn{width:100%; justify-content:center}.consent-row{grid-template-columns:20px 1fr}}

/* Stap 5.2: WhatsApp, spam/AVG-afwerking en lange paginatitels */
.whatsapp-option{
  margin-top:24px;
  padding-top:22px;
  border-top:1px solid var(--line);
}
.whatsapp-option h3{margin-bottom:8px}
.whatsapp-option p{color:var(--muted); max-width:720px}
.whatsapp-btn{border-color:rgba(130,199,200,.38)}
.page-hero h1{
  overflow-wrap:normal;
  word-break:normal;
  hyphens:none;
}
@media (max-width:980px){
  .page-hero h1{font-size:clamp(2.6rem, 9vw, 4.8rem)}
}
@media (max-width:640px){
  .page-hero h1{font-size:clamp(2.25rem, 10.5vw, 3.2rem); letter-spacing:-.045em}
}


/* Stap 5.3: responsive fix voor lange Nederlandse woorden op pagina's */
.page-main,
.page-hero,
.page-content-section,
.page-content,
.content-card,
.card{
  max-width:100%;
  overflow-x:hidden;
}
.page-hero .wrap,
.page-content-section .wrap{
  min-width:0;
}
.page-hero h1,
.content-card h1,
.content-card h2,
.content-card h3,
.page-content h1,
.page-content h2,
.page-content h3{
  max-width:100%;
  overflow-wrap:anywhere;
  word-break:normal;
  hyphens:auto;
}
@media (max-width:640px){
  .page-hero h1{
    font-size:clamp(2rem, 9.5vw, 2.95rem);
    line-height:1;
    letter-spacing:-.04em;
  }
  .content-card h2{
    font-size:clamp(1.85rem, 8vw, 2.65rem);
    line-height:1.02;
  }
  .page-hero-grid{
    gap:14px;
  }
}

/* Stap 6: nette korte paginatitels op mobiel */
@media (max-width:640px){
  .page-hero h1{
    overflow-wrap:normal;
    word-break:normal;
    hyphens:none;
    text-wrap:balance;
  }
}
@media (max-width:360px){
  .page-hero h1{font-size:clamp(1.9rem, 8.8vw, 2.65rem)}
}

/* Stap 7: inhoudspagina's netter en korte veiligheidstitels */
.page-content h3{margin-top:28px;margin-bottom:10px;color:var(--paper)}
.page-content .content-card + .content-card,
.page-content .grid3 + .content-card{margin-top:28px}
.page-content a:not(.btn){color:var(--cyan);text-decoration:none;border-bottom:1px solid rgba(130,199,200,.35)}
.page-content a:not(.btn):hover{border-bottom-color:rgba(130,199,200,.8)}
@media (max-width:640px){
  .page-content-section{padding-top:42px}
  .page-hero h1{font-size:clamp(2.15rem, 9vw, 2.9rem)}
  .page-content .content-card{padding:26px 22px}
}

/* Stap 8: visuele afwerking, fotoplekken en beheerbare beelden */
:focus-visible{outline:3px solid rgba(130,199,200,.92); outline-offset:4px; border-radius:10px}
header{box-shadow:0 12px 34px rgba(0,0,0,.24)}
.hero-card,.photo,.content-card,.panel,.card,.activity{backface-visibility:hidden}
.photo{background:
  radial-gradient(circle at 35% 24%, rgba(130,199,200,.14), transparent 22%),
  radial-gradient(circle at 72% 28%, rgba(217,31,38,.22), transparent 28%),
  linear-gradient(135deg, rgba(244,239,231,.07), rgba(0,0,0,.28));
}
.photo:before{filter:saturate(1.04) contrast(1.06)}
.photo:after{display:block; opacity:0; transform:translateY(8px); transition:.22s ease; pointer-events:none}
.photo:hover:after{opacity:1; transform:translateY(0)}
.photo.p1{--bgimg:radial-gradient(circle at 58% 36%, rgba(217,31,38,.42), transparent 23%), linear-gradient(130deg, rgba(0,0,0,.08), rgba(0,0,0,.74)), repeating-linear-gradient(0deg, rgba(214,168,91,.16), rgba(214,168,91,.16) 1px, transparent 1px, transparent 42px)}
.photo.p2{--bgimg:radial-gradient(circle at 50% 50%, rgba(244,239,231,.13), transparent 24%), linear-gradient(145deg, rgba(70,26,20,.55), rgba(0,0,0,.78))}
.photo.p3{--bgimg:radial-gradient(circle at 28% 36%, rgba(130,199,200,.16), transparent 25%), linear-gradient(135deg, rgba(0,0,0,.3), rgba(68,9,14,.82))}
.photo.p4{--bgimg:radial-gradient(circle at 68% 34%, rgba(217,31,38,.22), transparent 28%), linear-gradient(135deg, rgba(0,0,0,.2), rgba(0,0,0,.86))}
.photo.p5{--bgimg:radial-gradient(circle at 72% 24%, rgba(214,168,91,.28), transparent 26%), linear-gradient(150deg, rgba(15,102,112,.26), rgba(0,0,0,.78))}
.page-visual{width:210px; aspect-ratio:1/1; border-radius:34px; overflow:hidden; border:1px solid var(--line); box-shadow:var(--shadow); background:#111}
.page-visual img{width:100%; height:100%; object-fit:cover; display:block; filter:saturate(.92) contrast(1.08) brightness(.82)}
.page-visual:after{content:""; position:absolute}
.page-hero-grid{align-items:center}
.footer-list a{transition:.18s ease}.footer-list a:hover{color:var(--ao2)}
@media (max-width:980px){.page-visual{width:160px; border-radius:28px}}
@media (max-width:640px){
  .hero{padding-top:70px}
  .photo-grid{gap:12px}
  .photo:after{opacity:1; transform:none; font-size:.78rem; padding:9px 10px}
  .page-visual{display:none}
  .brand img{width:46px;height:46px}
}
@media (prefers-reduced-motion:reduce){*,*::before,*::after{scroll-behavior:auto!important;transition:none!important;animation:none!important}.btn:hover{transform:none}}


/* Stap 10: desktop/zoom hero-finishing en lokale live-afwerking */
@media (min-width: 981px){
  .hero-grid{grid-template-columns:minmax(0,1.12fr) minmax(360px,.88fr); gap:34px}
  .hero-text h1{font-size:clamp(4.15rem, 6.35vw, 5.85rem); line-height:.91; letter-spacing:-.058em; max-width:920px}
  .hero-card{min-height:560px}
}
@media (min-width: 981px) and (max-width: 1250px){
  .hero-grid{grid-template-columns:minmax(0,1fr) minmax(330px,.78fr); gap:28px}
  .hero-text h1{font-size:clamp(3.65rem, 6vw, 4.85rem); max-width:760px}
  .hero-card{min-height:500px}
}
@media (min-width: 641px) and (max-width: 980px){
  .hero-text h1{font-size:clamp(4.2rem, 10vw, 5.8rem)}
}
.hero-text .lead{max-width:720px}
/* Houd juridische en praktische pagina's rustiger op kleine schermen. */
@media (max-width: 420px){
  .page-hero h1{font-size:clamp(2rem, 8.2vw, 2.45rem); line-height:1.02; letter-spacing:-.035em}
  .content-card h1,.content-card h2{font-size:clamp(1.9rem, 8vw, 2.55rem); line-height:1.02}
}


/* Stap 10.1: paginabreedte afstemmen op de homepage */
:root{--page-max:1120px;}
.page-hero .wrap,
.page-content-section .wrap{
  max-width:var(--page-max);
}
.page-hero h1{
  max-width:820px;
}
.page-grid{
  grid-template-columns:minmax(0,1.08fr) minmax(300px,.92fr);
}
@media (max-width:980px){
  .page-hero .wrap,
  .page-content-section .wrap{max-width:var(--max)}
  .page-grid{grid-template-columns:1fr}
}
@media (max-width:640px){
  .page-hero .wrap,
  .page-content-section .wrap{padding-left:20px; padding-right:20px}
}


/* Stap 10.2: losse pagina's exact dezelfde containerbreedte als de homepage */
:root{--page-max:var(--max);}
.page-hero .wrap,
.page-content-section .wrap,
.page-main footer .wrap{
  width:100%;
  max-width:var(--max);
  margin-left:auto;
  margin-right:auto;
  padding-left:24px;
  padding-right:24px;
}
.page-hero-grid,
.page-grid,
.page-content{
  width:100%;
  max-width:100%;
}
.page-hero h1{
  max-width:920px;
}
.content-card,
.page-cards,
.page-time{
  width:100%;
}
@media (max-width:640px){
  .page-hero .wrap,
  .page-content-section .wrap,
  .page-main footer .wrap,
  .wrap{
    padding-left:20px;
    padding-right:20px;
  }
}

/* Stap 11a - Hero identity upgrade met Aotaka logo v5 en ven/havik-beeld */
.brand img{
  width:58px;
  height:58px;
  border-radius:50%;
  object-fit:cover;
  background:#fff;
  padding:0;
}
.nav{height:88px}
.hero-photo{
  position:relative;
  min-height:calc(100vh - 88px);
  padding:84px 0 36px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  overflow:hidden;
  background:#050607;
  border-bottom:1px solid var(--line);
}
.hero-photo:after{content:none !important;}
.hero-photo-bg{
  position:absolute;
  inset:0;
  background-image:url('../img/hero-aotaka-ven-havik.webp');
  background-size:cover;
  background-position:center center;
  transform:scale(1.012);
  filter:saturate(.92) contrast(1.04) brightness(.78);
  z-index:0;
}
.hero-photo-overlay{
  position:absolute;
  inset:0;
  z-index:1;
  background:
    linear-gradient(90deg, rgba(2,4,6,.96) 0%, rgba(2,4,6,.86) 22%, rgba(2,4,6,.42) 48%, rgba(2,4,6,.20) 74%, rgba(2,4,6,.50) 100%),
    linear-gradient(180deg, rgba(2,4,6,.52) 0%, rgba(2,4,6,.12) 38%, rgba(2,4,6,.78) 100%);
  pointer-events:none;
}
.hero-photo-grid{
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:minmax(0, 560px) minmax(0, 1fr);
  gap:32px;
  align-items:center;
  width:100%;
}
.hero-photo-text{
  max-width:620px;
  padding:44px 0 28px;
}
.hero-photo h1{
  font-size:clamp(3.5rem, 7.2vw, 6.9rem);
  line-height:.91;
  margin:18px 0 26px;
  text-shadow:0 8px 28px rgba(0,0,0,.48);
}
.hero-photo .lead{
  max-width:540px;
  color:#f1e9df;
  text-shadow:0 4px 18px rgba(0,0,0,.55);
}
.hero-photo .btnrow{margin-top:28px}
.hero-photo .btn.ghost{
  background:rgba(0,0,0,.30);
  border-color:rgba(244,239,231,.26);
  backdrop-filter:blur(12px);
}
.hero-photo .hero-tags{margin-top:24px; max-width:620px}
.hero-photo .tag{
  background:rgba(0,0,0,.32);
  border-color:rgba(244,239,231,.16);
  backdrop-filter:blur(10px);
}
.hero-value-wrap{
  position:relative;
  z-index:3;
  width:100%;
}
.hero-values{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:0;
  margin-top:30px;
  border:1px solid rgba(244,239,231,.16);
  border-radius:26px;
  background:rgba(6,8,10,.66);
  backdrop-filter:blur(18px);
  box-shadow:0 18px 60px rgba(0,0,0,.32);
  overflow:hidden;
}
.hero-value{
  min-height:88px;
  padding:20px 26px;
  display:flex;
  gap:16px;
  align-items:center;
  border-right:1px solid rgba(244,239,231,.13);
}
.hero-value:last-child{border-right:0}
.hero-value strong{
  display:block;
  font-size:1rem;
  color:#fff;
  line-height:1.2;
}
.hero-value em{
  display:block;
  margin-top:4px;
  font-style:normal;
  color:#d4c9bd;
  line-height:1.25;
}
.value-icon{
  flex:0 0 42px;
  width:42px;
  height:42px;
  display:grid;
  place-items:center;
  color:var(--red);
  border:1px solid rgba(217,31,38,.44);
  border-radius:50%;
  font-family:"Hiragino Mincho ProN", "Yu Mincho", Georgia, serif;
  font-weight:800;
  box-shadow:0 0 28px rgba(217,31,38,.12) inset;
}
@media (max-width: 1040px){
  .hero-photo{
    min-height:760px;
    padding-top:70px;
  }
  .hero-photo-grid{grid-template-columns:1fr;}
  .hero-photo-bg{background-position:62% center;}
  .hero-photo h1{font-size:clamp(3.0rem, 8.5vw, 5.4rem);}
  .hero-values{grid-template-columns:repeat(2, 1fr);}
  .hero-value:nth-child(2){border-right:0}
  .hero-value:nth-child(-n+2){border-bottom:1px solid rgba(244,239,231,.13)}
}
@media (max-width: 720px){
  .nav{height:76px}
  .brand img{width:48px;height:48px}
  .hero-photo{
    min-height:auto;
    padding:52px 0 34px;
  }
  .hero-photo-bg{
    background-position:62% center;
    filter:saturate(.88) contrast(1.05) brightness(.66);
  }
  .hero-photo-overlay{
    background:
      linear-gradient(90deg, rgba(2,4,6,.95) 0%, rgba(2,4,6,.82) 58%, rgba(2,4,6,.52) 100%),
      linear-gradient(180deg, rgba(2,4,6,.54) 0%, rgba(2,4,6,.20) 42%, rgba(2,4,6,.92) 100%);
  }
  .hero-photo-text{padding:34px 0 12px;}
  .hero-photo h1{
    font-size:clamp(2.55rem, 15vw, 4.05rem);
    max-width:340px;
  }
  .hero-photo .lead{font-size:1.03rem; max-width:340px;}
  .hero-photo .btnrow{align-items:stretch}
  .hero-photo .btn{width:100%; max-width:310px;}
  .hero-photo .hero-tags{display:none;}
  .hero-values{
    grid-template-columns:1fr;
    margin-top:24px;
    border-radius:22px;
  }
  .hero-value{
    min-height:70px;
    padding:16px 18px;
    border-right:0;
    border-bottom:1px solid rgba(244,239,231,.13);
  }
  .hero-value:last-child{border-bottom:0}
}
@media (max-width: 380px){
  .hero-photo h1{font-size:2.7rem;}
  .hero-photo .lead{font-size:.98rem;}
}

/* Stap 11b: compactere hero met bredere ven/havik-achtergrond */
.hero-photo{
  min-height:clamp(620px, calc(100vh - 88px), 760px);
  padding:58px 0 28px;
  justify-content:flex-end;
}
.hero-photo-bg{
  background-image:url('../img/hero-aotaka-ven-havik-wide.webp');
  background-size:cover;
  background-position:center center;
  transform:none;
  filter:saturate(.92) contrast(1.04) brightness(.84);
}
.hero-photo-overlay{
  background:
    linear-gradient(90deg, rgba(2,4,6,.74) 0%, rgba(2,4,6,.52) 33%, rgba(2,4,6,.10) 62%, rgba(2,4,6,.24) 100%),
    linear-gradient(180deg, rgba(2,4,6,.46) 0%, rgba(2,4,6,.04) 42%, rgba(2,4,6,.74) 100%);
}
.hero-photo-grid{grid-template-columns:minmax(0, 560px) minmax(0, 1fr);}
.hero-photo-text{padding:20px 0 18px; max-width:600px;}
.hero-photo h1{
  font-size:clamp(3.35rem, 5.85vw, 5.65rem);
  line-height:.94;
  margin:16px 0 22px;
  max-width:740px;
}
.hero-photo .lead{font-size:clamp(1.05rem,1.55vw,1.28rem); line-height:1.55; max-width:560px;}
.hero-photo .btnrow{margin-top:24px}
.hero-photo .hero-tags{margin-top:20px}
.hero-values{margin-top:22px;}
.hero-value{min-height:78px; padding:17px 24px;}
@media (min-width: 1400px){
  .hero-photo h1{font-size:clamp(3.7rem, 5.35vw, 5.9rem)}
  .hero-photo{min-height:720px;}
}
@media (max-width: 1040px){
  .hero-photo{min-height:700px; padding-top:58px;}
  .hero-photo-bg{background-position:62% center;}
  .hero-photo h1{font-size:clamp(3.0rem, 7.8vw, 5.0rem);}
}
@media (max-width: 720px){
  .hero-photo{padding:44px 0 30px; min-height:auto;}
  .hero-photo-bg{background-position:58% center; filter:saturate(.88) contrast(1.05) brightness(.62);}
  .hero-photo-overlay{
    background:
      linear-gradient(90deg, rgba(2,4,6,.96) 0%, rgba(2,4,6,.82) 62%, rgba(2,4,6,.52) 100%),
      linear-gradient(180deg, rgba(2,4,6,.56) 0%, rgba(2,4,6,.24) 42%, rgba(2,4,6,.92) 100%);
  }
  .hero-photo-text{padding:28px 0 8px;}
  .hero-photo h1{font-size:clamp(2.45rem, 13.2vw, 3.8rem); max-width:340px;}
  .hero-photo .lead{font-size:1rem; max-width:340px;}
  .hero-values{margin-top:18px;}
}


/* Stap 11c: hero-finishing voor betere desktop- en mobiele balans */
.hero-photo{
  min-height:clamp(560px, calc(100vh - 88px), 680px);
  padding:46px 0 24px;
}
.hero-photo-bg{
  background-position:64% center;
  filter:saturate(.90) contrast(1.05) brightness(.80);
}
.hero-photo-overlay{
  background:
    linear-gradient(90deg, rgba(2,4,6,.82) 0%, rgba(2,4,6,.62) 30%, rgba(2,4,6,.16) 58%, rgba(2,4,6,.30) 100%),
    linear-gradient(180deg, rgba(2,4,6,.50) 0%, rgba(2,4,6,.06) 44%, rgba(2,4,6,.80) 100%);
}
.hero-photo-grid{
  grid-template-columns:minmax(0, 540px) minmax(0, 1fr);
}
.hero-photo-text{
  max-width:560px;
  padding:12px 0 12px;
}
.hero-photo h1{
  font-size:clamp(3.05rem, 5.05vw, 5.05rem);
  line-height:.96;
  margin:14px 0 20px;
  max-width:650px;
}
.hero-photo .lead{
  font-size:clamp(1.02rem,1.35vw,1.18rem);
  line-height:1.55;
  max-width:530px;
}
.hero-photo .btnrow{margin-top:22px;}
.hero-photo .hero-tags{margin-top:18px;}
.hero-value-wrap{padding-bottom:6px;}
.hero-values{margin-top:18px;}
.hero-value{min-height:72px; padding:15px 22px;}

@media (min-width: 1400px){
  .hero-photo{min-height:680px;}
  .hero-photo h1{font-size:clamp(3.35rem, 4.85vw, 5.45rem);}
}
@media (max-width: 1200px){
  .hero-photo h1{font-size:clamp(3rem, 5.6vw, 4.9rem);}
  .hero-photo-bg{background-position:66% center;}
}
@media (max-width: 1040px){
  .hero-photo{min-height:640px; padding-top:46px;}
  .hero-photo-grid{grid-template-columns:1fr;}
  .hero-photo-bg{background-position:65% center;}
  .hero-photo h1{font-size:clamp(2.9rem, 7.0vw, 4.5rem); max-width:560px;}
  .hero-photo .lead{max-width:500px;}
}
@media (max-width: 720px){
  .hero-photo{
    min-height:auto;
    padding:34px 0 24px;
  }
  .hero-photo-bg{
    background-position:68% center;
    filter:saturate(.86) contrast(1.05) brightness(.56);
  }
  .hero-photo-overlay{
    background:
      linear-gradient(90deg, rgba(2,4,6,.96) 0%, rgba(2,4,6,.84) 58%, rgba(2,4,6,.56) 100%),
      linear-gradient(180deg, rgba(2,4,6,.62) 0%, rgba(2,4,6,.28) 46%, rgba(2,4,6,.94) 100%);
  }
  .hero-photo-text{padding:18px 0 6px;}
  .hero-photo .eyebrow{font-size:.70rem; letter-spacing:.15em;}
  .hero-photo h1{
    font-size:clamp(2.22rem, 11.8vw, 3.15rem);
    line-height:.98;
    max-width:330px;
    margin:12px 0 18px;
  }
  .hero-photo .lead{font-size:.96rem; line-height:1.5; max-width:320px;}
  .hero-photo .btnrow{margin-top:18px; gap:10px;}
  .hero-photo .btn{width:100%; max-width:300px; justify-content:center;}
  .hero-values{margin-top:16px;}
}
@media (max-width: 380px){
  .hero-photo{padding-top:28px;}
  .hero-photo-bg{background-position:70% center;}
  .hero-photo h1{font-size:2.34rem; max-width:285px;}
  .hero-photo .lead{font-size:.94rem; max-width:290px;}
}

/* Stap 12: samenwerking met Judo Ryu Maasduinen */
.partner-block{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(280px,.78fr);
  gap:28px;
  align-items:center;
  border:1px solid var(--line);
  border-radius:36px;
  padding:32px;
  background:linear-gradient(135deg, rgba(217,31,38,.12), rgba(15,102,112,.12)), rgba(255,255,255,.045);
  box-shadow:0 22px 70px rgba(0,0,0,.28);
  overflow:hidden;
}
.partner-text{min-width:0}
.partner-logo-card{
  border:1px solid rgba(244,239,231,.13);
  border-radius:30px;
  padding:18px;
  background:rgba(244,239,231,.95);
  display:grid;
  place-items:center;
  min-height:300px;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.04), 0 18px 55px rgba(0,0,0,.22);
}
.partner-logo-card img{
  display:block;
  width:100%;
  height:auto;
  max-height:420px;
  object-fit:contain;
}
@media (max-width:900px){
  .partner-block{grid-template-columns:1fr; padding:24px; border-radius:28px}
  .partner-logo-card{min-height:220px; padding:14px}
}
@media (max-width:560px){
  .partner-block{padding:18px; gap:18px}
  .partner-logo-card{border-radius:22px; min-height:180px}
}

/* Stap 12.2: makiwara/seiken impactbeeld voor homepage en karatepagina */
.karate-meaning-impact{
  grid-template-columns:1.05fr .95fr;
}
.impact-image-card{
  min-height:460px;
  background:
    linear-gradient(90deg, rgba(4,5,6,.26), rgba(4,5,6,.10)),
    linear-gradient(180deg, rgba(4,5,6,.06), rgba(4,5,6,.78)),
    url('../img/makiwara-seiken-impact-v13.webp') center center / cover no-repeat;
  box-shadow:0 28px 80px rgba(0,0,0,.36);
}
.impact-image-card:before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 78% 18%, rgba(217,31,38,.24), transparent 28%),
    linear-gradient(90deg, rgba(0,0,0,.08), rgba(0,0,0,.04));
  pointer-events:none;
}
.impact-image-card:after{
  content:"";
  position:absolute;
  inset:auto 0 0 0;
  height:48%;
  background:linear-gradient(180deg, transparent, rgba(0,0,0,.82));
  pointer-events:none;
}
.impact-caption{
  background:linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,.52));
  border:1px solid rgba(244,239,231,.13);
  border-radius:22px;
  padding:16px;
  backdrop-filter:blur(8px);
}
.impact-caption h3{margin-top:14px;font-size:1.55rem}
.impact-caption p{margin-bottom:0}
.media-card{
  overflow:hidden;
  padding:0;
}
.media-card img{
  display:block;
  width:100%;
  height:100%;
  min-height:360px;
  object-fit:cover;
}
.makiwara-page-card{
  position:relative;
  border-radius:30px;
}
.makiwara-page-card:after{
  content:"Seiken op makiwara · kracht met controle";
  position:absolute;
  left:18px;
  right:18px;
  bottom:18px;
  padding:12px 14px;
  border-radius:16px;
  color:#fff;
  font-weight:850;
  letter-spacing:.01em;
  background:rgba(0,0,0,.56);
  border:1px solid rgba(244,239,231,.14);
  backdrop-filter:blur(10px);
}
.karate-page-impact{align-items:stretch}
@media (max-width:980px){
  .karate-meaning-impact{grid-template-columns:1fr}
  .impact-image-card{min-height:420px;background-position:center center}
}
@media (max-width:640px){
  .impact-image-card{min-height:320px;border-radius:26px;background-position:58% center}
  .impact-caption{left:18px;right:18px;bottom:18px;padding:14px}
  .impact-caption h3{font-size:1.25rem}
  .media-card img{min-height:260px}
  .makiwara-page-card:after{font-size:.85rem;left:12px;right:12px;bottom:12px}
}

/* Stap 12.3: correctie fout makiwara-beeld + uitlijning kaarten */
.page-grid > .content-card + .content-card,
.page-grid > .card + .card,
.page-grid > .content-card.dark + .content-card.dark{
  margin-top:0 !important;
}
.page-grid > .content-card{
  align-self:stretch;
}
.time-card > div:nth-child(2){
  min-width:0;
}
.time-card strong,
.time-card span{
  display:block;
}
.time-card strong{
  margin-bottom:2px;
}
@media (max-width:720px){
  .time-card{align-items:start; gap:10px;}
}


/* Stap 12.4: juiste makiwara/seiken beeld + nette trainingstijdenkaarten */
.karate-meaning-impact{
  grid-template-columns:.88fr 1.12fr;
  align-items:stretch;
  margin-bottom:24px;
}
.homepage-impact-card{
  border-radius:34px;
  min-height:420px;
  border:1px solid var(--line);
  position:relative;
  overflow:hidden;
  background:
    linear-gradient(90deg, rgba(2,3,4,.10), rgba(2,3,4,.20)),
    linear-gradient(180deg, rgba(2,3,4,.02), rgba(2,3,4,.72)),
    url('../img/makiwara-seiken-impact-v13.webp') center center / cover no-repeat;
}
.homepage-impact-card:after{
  content:attr(data-caption);
  position:absolute;
  left:18px;
  right:18px;
  bottom:18px;
  padding:12px 14px;
  border-radius:16px;
  color:#fff;
  font-weight:850;
  background:rgba(0,0,0,.56);
  border:1px solid rgba(244,239,231,.14);
  backdrop-filter:blur(10px);
}
.pillars-after-impact{
  grid-template-columns:repeat(4,1fr);
  margin-top:0;
}
.training-info-grid{
  align-items:stretch;
  margin-top:24px;
}
.training-info-grid .content-card{
  height:100%;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
}
@media (max-width:1100px){
  .pillars-after-impact{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:980px){
  .karate-meaning-impact{grid-template-columns:1fr}
  .homepage-impact-card{min-height:340px;background-position:58% center}
}
@media (max-width:640px){
  .homepage-impact-card{min-height:260px;border-radius:26px;background-position:62% center}
  .homepage-impact-card:after{font-size:.82rem;left:12px;right:12px;bottom:12px}
  .pillars-after-impact{grid-template-columns:1fr}
  .training-info-grid{margin-top:18px}
}


/* Stap 12.5: homepage makiwara-beeld rustiger, juiste uitsnede en trainingstijden strakker */
.karate-meaning-impact{
  grid-template-columns:.82fr 1.18fr;
  gap:24px;
  align-items:stretch;
}
.karate-meaning-impact .impact-text-card{
  min-height:340px;
  box-shadow:0 18px 55px rgba(0,0,0,.24);
}
.karate-meaning-impact .impact-text-card .meaning-content{
  left:24px;
  right:24px;
  bottom:22px;
}
.homepage-impact-card{
  min-height:340px;
  border-radius:30px;
  background:
    linear-gradient(90deg, rgba(2,3,4,.04), rgba(2,3,4,.10)),
    linear-gradient(180deg, rgba(2,3,4,.00), rgba(2,3,4,.38)),
    url('../img/makiwara-seiken-impact-v13.webp') 72% center / cover no-repeat;
}
.homepage-impact-card:before{
  opacity:.55;
}
.homepage-impact-card:after{
  content:attr(data-caption);
  position:absolute;
  inset:auto 18px 18px 18px;
  height:auto !important;
  display:block;
  padding:12px 14px;
  border-radius:16px;
  color:#fff;
  font-weight:850;
  background:rgba(0,0,0,.56);
  border:1px solid rgba(244,239,231,.14);
  backdrop-filter:blur(10px);
}
.makiwara-page-card img,
.media-card.makiwara-page-card img{
  object-position:72% center;
}
.training-info-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  align-items:stretch;
  gap:24px;
  margin-top:24px;
}
.training-info-grid .content-card{
  height:100%;
  margin-top:0 !important;
}
.time-card{
  grid-template-columns:110px minmax(0, 1fr) auto;
}
.time-card .time{
  white-space:nowrap;
}
@media (max-width:980px){
  .karate-meaning-impact{grid-template-columns:1fr;}
  .homepage-impact-card{min-height:320px;background-position:72% center;}
  .training-info-grid{grid-template-columns:1fr;}
}
@media (max-width:640px){
  .karate-meaning-impact .impact-text-card{min-height:300px;}
  .homepage-impact-card{min-height:250px;background-position:76% center;border-radius:24px;}
  .homepage-impact-card:after{font-size:.82rem;inset:auto 12px 12px 12px;padding:10px 12px;}
  .time-card{grid-template-columns:1fr;}
  .time-card .time{justify-self:start;}
}


/* Stap 13: inhoudelijke afwerking proefles, programma's, contributie en samenwerking */
.homepage-impact-card{
  background-size:cover;
  background-repeat:no-repeat;
}

.makiwara-page-card img{object-position:72% center !important;}
.practical-note{padding:18px 20px;border:1px solid rgba(130,199,200,.22);border-radius:20px;background:rgba(15,102,112,.10);}
.practical-note strong{color:var(--ink)}
.page-cards .card .meta{display:inline-flex;margin-bottom:10px;color:var(--ao2);font-weight:900;letter-spacing:.04em;font-size:.82rem;text-transform:uppercase}
.tarief-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:24px}
.tarief-card{padding:22px;border:1px solid var(--line);border-radius:24px;background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.025));min-height:100%}
.tarief-card h3{margin-top:0}
.tarief-card p{margin-bottom:0;color:var(--muted)}
@media (max-width:900px){.tarief-grid{grid-template-columns:1fr}}

/* Stap 15: handmatig vervangbare fotografieblokken via de Customizer. */
.activity{
  background-size:cover;
  background-position:var(--activity-pos, center center);
}
.photo:before{
  background-size:cover;
  background-position:var(--photo-pos, center center);
}
.instructor-art{
  background-size:cover;
  background-position:var(--instructor-pos, center center);
}
.instructor-art[style*="background-image"]:before{
  background:linear-gradient(180deg, rgba(0,0,0,.04), rgba(0,0,0,.68)), radial-gradient(circle at 54% 24%, rgba(217,31,38,.18), transparent 26%);
}

/* Stap 16: nette tabellen en downloadblokken */
.fee-table-wrap{overflow-x:auto;margin:24px 0;border:1px solid rgba(244,239,231,.14);border-radius:18px;background:rgba(255,255,255,.03)}
.fee-table{width:100%;border-collapse:collapse;min-width:760px;color:var(--ink)}
.fee-table th,.fee-table td{padding:14px 16px;border-bottom:1px solid rgba(244,239,231,.1);text-align:left;vertical-align:top}
.fee-table th{font-size:13px;text-transform:uppercase;letter-spacing:.08em;color:#83d8dc;background:rgba(255,255,255,.04)}
.fee-table tr:last-child td{border-bottom:0}
.fee-table td:last-child,.fee-table th:last-child{text-align:right}
.info-strip{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin:22px 0}
.info-pill{border:1px solid rgba(244,239,231,.14);border-radius:18px;padding:18px;background:rgba(255,255,255,.04);color:var(--muted)}
.info-pill strong{display:block;margin-bottom:6px;color:var(--ink)}
.download-list{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-top:18px}
.download-card{border:1px solid rgba(244,239,231,.14);border-radius:20px;padding:18px;background:rgba(255,255,255,.04)}
.download-card h3{margin:0 0 8px}
.download-card p{margin:0 0 14px;color:var(--muted)}
.safety-note{border-left:3px solid var(--red);padding-left:18px;color:var(--muted)}
@media(max-width:800px){.info-strip,.download-list{grid-template-columns:1fr}.fee-table{min-width:680px}}

/* Stap 17: formulier goed zichtbaar en menu/kaart afwerking */
.aotaka-form label{display:grid;gap:8px;color:#f4efe7;font-weight:760;font-size:.95rem}
.aotaka-form input:not([type="hidden"]):not([type="checkbox"]),
.aotaka-form select,
.aotaka-form textarea{
  display:block !important;
  width:100% !important;
  min-height:50px;
  border:1px solid rgba(244,239,231,.24) !important;
  border-radius:16px;
  padding:13px 15px;
  background:rgba(0,0,0,.42) !important;
  color:#f4efe7 !important;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.025);
  opacity:1 !important;
  visibility:visible !important;
  -webkit-appearance:auto;
  appearance:auto;
}
.aotaka-form textarea{min-height:132px}
.aotaka-form select option{background:#11161a;color:#f4efe7}
.aotaka-form input::placeholder,.aotaka-form textarea::placeholder{color:rgba(244,239,231,.48)}
.aotaka-form input:focus,.aotaka-form select:focus,.aotaka-form textarea:focus{border-color:rgba(130,199,200,.75) !important;box-shadow:0 0 0 3px rgba(130,199,200,.13);outline:0}
.aotaka-form .hp-field{position:absolute !important;left:-9999px !important;width:1px !important;height:1px !important;overflow:hidden !important}
.aotaka-form .consent-row input[type="checkbox"]{display:block !important;width:18px !important;height:18px !important;min-height:18px !important;margin-top:4px;accent-color:var(--red)}
.lesson-overview-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin:22px 0}
.lesson-mini-card{border:1px solid rgba(255,255,255,.12);border-radius:20px;padding:18px;background:rgba(255,255,255,.04)}
.lesson-mini-card h3{margin:0 0 8px}.lesson-mini-card p{margin:0;color:var(--muted)}
@media(max-width:980px){.lesson-overview-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:640px){.lesson-overview-grid{grid-template-columns:1fr}.aotaka-form input:not([type="hidden"]):not([type="checkbox"]),.aotaka-form select,.aotaka-form textarea{min-height:48px}}

/* Stap 19: visuele karatebasis en overzichtelijke programmapagina */
.karate-visual-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;margin:26px 0 22px}
.karate-visual-card{min-height:360px;border:1px solid rgba(244,239,231,.14);border-radius:28px;padding:24px;position:relative;overflow:hidden;background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.025));display:flex;flex-direction:column;justify-content:flex-end;box-shadow:0 24px 80px rgba(0,0,0,.18)}
.karate-visual-card:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 74% 22%,rgba(217,31,38,.46),transparent 26%),radial-gradient(circle at 22% 18%,rgba(130,199,200,.16),transparent 24%),linear-gradient(180deg,rgba(0,0,0,.03),rgba(0,0,0,.72));pointer-events:none}
.karate-visual-card:after{position:absolute;right:18px;top:12px;font-family:"Hiragino Mincho ProN","Yu Mincho",Georgia,serif;font-size:6.4rem;line-height:1;color:rgba(244,239,231,.09);font-weight:800;pointer-events:none}
.karate-visual-card.kihon:after{content:"基本"}.karate-visual-card.kata:after{content:"型"}.karate-visual-card.kumite:after{content:"組手"}
.karate-visual-card .visual-label,.karate-visual-card h3,.karate-visual-card p{position:relative;z-index:1}
.visual-label{display:inline-flex;align-self:flex-start;gap:8px;align-items:center;border:1px solid rgba(244,239,231,.16);border-radius:999px;padding:8px 12px;margin-bottom:14px;background:rgba(0,0,0,.28);color:var(--ao2);font-size:.75rem;font-weight:900;letter-spacing:.1em;text-transform:uppercase}
.karate-visual-card h3{font-size:clamp(1.7rem,3vw,2.6rem);margin:0 0 10px}.karate-visual-card p{color:var(--muted);margin:0;line-height:1.6}
.karate-visual-note{border-left:3px solid var(--red);padding-left:18px;color:var(--muted);margin-top:12px}
.program-selector-card{margin-top:26px}.program-selector-card .program-grid{margin-top:20px}.program-page-intro{margin-bottom:22px}.program-detail .program-extra{margin-top:18px;border:1px solid rgba(130,199,200,.22);border-radius:22px;padding:18px;background:rgba(130,199,200,.055);color:var(--muted)}
.program-detail .program-extra strong{color:var(--ink)}
.program-detail .badge-chip-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}.program-detail .badge-chip-row span{display:inline-flex;border:1px solid rgba(244,239,231,.16);border-radius:999px;padding:8px 11px;background:rgba(255,255,255,.045);font-size:.9rem;color:#e6dbcf}
.program-action-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:20px}.program-action-row .btn{white-space:normal}.program-times-anchor{margin-top:28px}
@media(max-width:980px){.karate-visual-grid{grid-template-columns:1fr}.karate-visual-card{min-height:280px}.program-grid{grid-template-columns:1fr}}


/* Stap 21: afronding proeflesstappen, samenwerking, Juku en over-de-dojo */
.step-list{display:grid;gap:14px;margin-top:18px}
.step-card{display:grid;grid-template-columns:64px 1fr;gap:20px;align-items:start;border:1px solid rgba(244,239,231,.14);border-radius:26px;padding:20px;background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.02))}
.step-card > span{width:52px;height:52px;border-radius:50%;display:inline-grid;place-items:center;background:radial-gradient(circle at 35% 30%,#ed333b,#b9141d);color:#fff;font-weight:900;font-size:1.35rem;box-shadow:0 16px 34px rgba(217,31,38,.26)}
.step-card h3{margin:0 0 7px}.step-card p{margin:0;color:var(--muted);line-height:1.55}
.page-partner-split{display:grid;grid-template-columns:1.05fr .7fr;gap:28px;align-items:center}
.page-partner-logo{border-radius:24px;padding:18px;background:rgba(244,239,231,.92);border:1px solid rgba(255,255,255,.26);box-shadow:0 28px 80px rgba(0,0,0,.25)}
.page-partner-logo img{display:block;width:100%;height:auto;border-radius:14px}
.karate-visual-card{min-height:340px}
.karate-visual-card h3{min-height:52px;display:flex;align-items:flex-end}
.karate-visual-card p{min-height:102px}
.juku-feature-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-top:22px}
.juku-feature-card{border:1px solid rgba(244,239,231,.14);border-radius:22px;padding:18px;background:rgba(255,255,255,.04)}
.juku-feature-card h3{margin:0 0 8px}.juku-feature-card p{margin:0;color:var(--muted)}
.instructor-art:after{content:attr(data-title);position:absolute;left:22px;right:22px;bottom:22px;border:1px solid rgba(244,239,231,.14);border-radius:18px;padding:14px 16px;background:rgba(0,0,0,.52);backdrop-filter:blur(10px);color:#f4efe7;font-weight:800;line-height:1.35;opacity:.94}
@media(max-width:900px){.page-partner-split{grid-template-columns:1fr}.juku-feature-grid{grid-template-columns:1fr}.karate-visual-card h3,.karate-visual-card p{min-height:0}}
@media(max-width:640px){.step-card{grid-template-columns:1fr;gap:12px}.step-card > span{width:46px;height:46px;font-size:1.15rem}.instructor-art:after{left:14px;right:14px;bottom:14px;font-size:.9rem}}

/* Stap 22: afronding externe teksten en proeflesstappen */
.step-card{grid-template-columns:58px minmax(0,1fr);align-items:start}
.step-card > div{min-width:0;width:100%}
.step-card h3,.step-card p{overflow-wrap:normal;word-break:normal;hyphens:none}
.step-card p{max-width:54ch}
@media(max-width:900px){.step-card{grid-template-columns:56px minmax(0,1fr)}}
@media(max-width:640px){.step-card{grid-template-columns:52px minmax(0,1fr);gap:14px}.step-card > span{width:46px;height:46px}.step-card h3{font-size:1.05rem}.step-card p{font-size:.95rem;line-height:1.5}}
.juku-feature-grid.juku-feature-grid-wide{grid-template-columns:1fr;gap:14px}
.juku-feature-grid-wide .juku-feature-card{display:grid;grid-template-columns:52px minmax(0,1fr);gap:14px;align-items:start}
.juku-feature-icon{width:44px;height:44px;border-radius:16px;display:grid;place-items:center;background:rgba(15,102,112,.75);color:#f4efe7;font-weight:900}
@media(max-width:640px){.juku-feature-grid-wide .juku-feature-card{grid-template-columns:1fr}.juku-feature-icon{width:40px;height:40px}}

/* Stap 22.1: correcties menu en proefles-stapkaarten */
.step-list{display:grid !important;gap:16px !important;margin-top:18px !important}
.step-card{display:flex !important;align-items:flex-start !important;gap:18px !important;width:100% !important;min-width:0 !important}
.step-card > span{flex:0 0 52px !important;width:52px !important;height:52px !important;min-width:52px !important}
.step-card > div{flex:1 1 auto !important;min-width:180px !important;width:auto !important;max-width:none !important}
.step-card h3{white-space:normal !important;word-break:normal !important;overflow-wrap:normal !important;hyphens:none !important}
.step-card p{max-width:none !important;white-space:normal !important;word-break:normal !important;overflow-wrap:normal !important;hyphens:none !important}
.nav nav #menu > li > a.btn.primary{margin-left:2px}
@media(max-width:640px){.step-card{gap:14px !important}.step-card > span{flex-basis:46px !important;width:46px !important;height:46px !important;min-width:46px !important}.step-card > div{min-width:0 !important}}

/* Stap 23: locatieblok, proefles-stappen en externe tekstafwerking */
.location-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:18px}
.mapbox.mapbox-link{display:block;color:inherit;text-decoration:none;min-height:220px}
.mapbox.mapbox-link:hover{border-color:rgba(130,199,200,.52);filter:brightness(1.06)}
.mapbox.mapbox-link:focus-visible{outline:3px solid rgba(130,199,200,.9);outline-offset:4px}
.mapbox .map-card-label{position:absolute;left:18px;top:18px;z-index:2}
.location-card .btn{white-space:nowrap}
.page-content .step-card,
.step-list .step-card{display:flex!important;align-items:flex-start!important;gap:18px!important;width:100%!important;min-width:0!important}
.page-content .step-card>span,
.step-list .step-card>span{flex:0 0 52px!important;width:52px!important;height:52px!important;min-width:52px!important}
.page-content .step-card>div,
.step-list .step-card>div{flex:1 1 auto!important;min-width:0!important;width:auto!important;max-width:none!important}
.page-content .step-card h3,
.page-content .step-card p,
.step-list .step-card h3,
.step-list .step-card p{white-space:normal!important;word-break:normal!important;overflow-wrap:normal!important;hyphens:none!important;max-width:none!important}
.page-content .step-card h3,
.step-list .step-card h3{font-size:1.05rem;line-height:1.2;margin:0 0 8px!important}
.page-content .step-card p,
.step-list .step-card p{line-height:1.55;margin:0!important}
@media(max-width:640px){
  .location-actions{display:grid}.location-actions .btn{width:100%;justify-content:center}
  .mapbox.mapbox-link{min-height:180px}
  .page-content .step-card,.step-list .step-card{gap:14px!important;padding:16px!important}
  .page-content .step-card>span,.step-list .step-card>span{flex-basis:46px!important;width:46px!important;height:46px!important;min-width:46px!important}
}

/* Stap 23.1: nette klikbare locatiekaart zonder iframe */
.mapbox.mapbox-link{
  position:relative;
  display:block;
  min-height:240px;
  border-radius:24px;
  overflow:hidden;
  border:1px solid rgba(244,239,231,.16);
  background:
    radial-gradient(circle at 58% 48%, rgba(217,31,38,.28), transparent 16%),
    radial-gradient(circle at 26% 28%, rgba(130,199,200,.18), transparent 20%),
    linear-gradient(145deg, rgba(10,42,45,.92), rgba(52,20,23,.88));
  text-decoration:none;
  color:#f4efe7;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.03);
}
.mapbox.mapbox-link:before{
  content:"";
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(90deg, rgba(255,255,255,.07) 1px, transparent 1px),
    linear-gradient(rgba(255,255,255,.055) 1px, transparent 1px),
    linear-gradient(28deg, transparent 0 44%, rgba(244,239,231,.18) 44% 46%, transparent 46% 100%),
    linear-gradient(-18deg, transparent 0 53%, rgba(130,199,200,.15) 53% 55%, transparent 55% 100%),
    linear-gradient(78deg, transparent 0 60%, rgba(244,239,231,.12) 60% 62%, transparent 62% 100%);
  background-size:40px 40px,40px 40px,100% 100%,100% 100%,100% 100%;
  opacity:.78;
}
.mapbox.mapbox-link:after{
  content:"Bergen · Maasduinen";
  position:absolute;
  top:18px;
  left:18px;
  z-index:2;
  color:rgba(244,239,231,.78);
  font-size:.78rem;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
  padding:8px 10px;
  border:1px solid rgba(244,239,231,.13);
  border-radius:999px;
  background:rgba(0,0,0,.24);
}
.mapbox.mapbox-link .map-pin,
.mapbox.mapbox-link > i.map-pin{
  position:absolute;
  left:54%;
  top:48%;
  z-index:3;
  transform:translate(-50%,-50%) rotate(-45deg);
  width:58px;
  height:58px;
  min-width:0;
  border-radius:50% 50% 50% 0;
  background:var(--red);
  box-shadow:0 14px 36px rgba(0,0,0,.48);
  padding:0;
  border:0;
}
.mapbox.mapbox-link .map-pin:after,
.mapbox.mapbox-link > i.map-pin:after{
  content:"";
  position:absolute;
  width:18px;
  height:18px;
  border-radius:50%;
  left:20px;
  top:20px;
  background:#101316;
}
.mapbox.mapbox-link .map-label,
.mapbox.mapbox-link > strong.map-label{
  position:absolute;
  left:18px;
  right:18px;
  bottom:16px;
  z-index:3;
  display:block;
  padding:12px 14px;
  border:1px solid rgba(244,239,231,.16);
  border-radius:16px;
  background:rgba(0,0,0,.48);
  color:#f4efe7;
  font-size:.9rem;
  font-weight:900;
  line-height:1.35;
  backdrop-filter:blur(10px);
}
.mapbox.mapbox-link:hover{filter:brightness(1.06);border-color:rgba(130,199,200,.5)}
@media(max-width:640px){.mapbox.mapbox-link{min-height:200px}.mapbox.mapbox-link .map-label,.mapbox.mapbox-link > strong.map-label{font-size:.82rem}.mapbox.mapbox-link:after{font-size:.7rem}}
