
/* ═══════════════════════════════════════════
   CIPHERENGINE BRAND TOKENS
   Navy  #043B7D | Teal  #09AE96 | Blue #1856A8
   Mid   #277589 | Dark  #00224F | Lt   #E7F0FA
═══════════════════════════════════════════ */
:root{
  --ce-navy:   #043B7D;
  --ce-dark:   #00224F;
  --ce-blue:   #1856A8;
  --ce-mid:    #277589;
  --ce-teal:   #09AE96;
  --ce-lt:     #E7F0FA;
  --ce-white:  #ffffff;

  --paper:     #F2F4F8;
  --card:      #ffffff;
  --rule:      #D0D6E0;
  --ink:       #0D1B36;
  --ink-mid:   #3A4A6B;
  --ink-lt:    #6B7A9A;

  --ok:        #0A6640;
  --ok-lt:     #E3F5EC;
  --err:       #8B2020;
  --err-lt:    #FDEAEA;
  --gold:      #B07D0C;
  --gold-lt:   #FEF3D6;

  --font-head: Georgia,'Times New Roman',serif;
  --font-body: 'Segoe UI',Helvetica,Arial,sans-serif;
  --font-ui:   'Segoe UI',Helvetica,Arial,sans-serif;
  --font-mono: 'Courier New',Courier,monospace;

  --sidebar-w: 252px;
  --sidebar-offset: var(--sidebar-w);
  --topbar-h:  54px;
  --goalbar-h: 58px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{background:var(--paper);color:var(--ink);font-family:var(--font-body);font-size:1rem;line-height:1.8;min-height:100vh;}

/* ── TOP BAR ────────────────────────────── */
#topbar{
  position:fixed;top:0;left:0;right:0;height:var(--topbar-h);
  background:var(--ce-dark);
  display:flex;align-items:center;padding:0 1.2rem;gap:1rem;z-index:300;
  border-bottom:2px solid var(--ce-teal);
}
/* CE Lock icon (inline SVG) */
.ce-lock-icon{flex-shrink:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;}
.ce-lock-icon svg{width:24px;height:24px;}
.ce-logo-text{
  font-family:var(--font-ui);font-size:1.05rem;font-weight:700;
  color:var(--ce-white);letter-spacing:0.06em;flex-shrink:0;
}
.ce-logo-text span{color:var(--ce-teal);}
.top-chapter{font-family:var(--font-ui);font-size:0.75rem;color:#9ABCD8;flex-shrink:0;white-space:nowrap;}
.top-spacer{flex:1;}
/* ── TAALWISSELAAR ─────────────────────────── */
#lang-switcher{flex-shrink:0;position:relative;}
.lang-btn{
  background:rgba(255,255,255,0.08);
  color:var(--ce-white);
  border:1px solid rgba(255,255,255,0.18);
  border-radius:5px;
  padding:4px 10px;
  font-size:0.88rem;
  font-family:var(--font-ui);
  cursor:pointer;
  display:flex;align-items:center;gap:6px;
  transition:background .15s;
  white-space:nowrap;
}
.lang-btn:hover{background:rgba(255,255,255,0.15);}
.lang-btn .lang-arrow{font-size:0.65rem;opacity:0.7;margin-left:2px;}
.lang-dropdown{
  position:absolute;
  top:calc(100% + 5px);
  right:0;
  background:var(--ce-dark);
  border:1px solid rgba(255,255,255,0.22);
  border-radius:6px;
  min-width:150px;
  z-index:500;
  display:none;
  box-shadow:0 4px 16px rgba(0,0,0,0.4);
  overflow:hidden;
}
.lang-dropdown.open{display:block;}
.lang-option{
  padding:8px 14px;
  cursor:pointer;
  color:var(--ce-white);
  font-size:0.85rem;
  font-family:var(--font-ui);
  display:flex;align-items:center;gap:8px;
  transition:background .1s;
}
.lang-option:hover{background:rgba(255,255,255,0.1);}
.lang-option.active{color:var(--ce-teal);font-weight:600;}

.prog-wrap{display:flex;align-items:center;gap:0.6rem;flex-shrink:0;}
.prog-track{width:130px;height:5px;background:#1a3a60;border-radius:3px;overflow:hidden;}
.prog-fill{height:100%;background:var(--ce-teal);border-radius:3px;width:0%;transition:width .5s ease;}
.prog-label{font-family:var(--font-ui);font-size:0.75rem;color:#9ABCD8;white-space:nowrap;min-width:4rem;text-align:right;}

/* ── GOAL BAR ───────────────────────────── */
#goalbar{
  position:fixed;top:var(--topbar-h);left:0;right:0;
  background:var(--ce-lt);border-bottom:2px solid #B8D0EC;
  padding:0.5rem 1.2rem;display:flex;align-items:flex-start;gap:0.7rem;
  z-index:290;height:var(--goalbar-h);overflow-y: auto;
}
.goal-tag{
  font-family:var(--font-ui);font-size:0.68rem;font-weight:700;letter-spacing:.1em;
  text-transform:uppercase;color:var(--ce-blue);white-space:nowrap;padding-top:2px;flex-shrink:0;
}
.goal-text{font-family:var(--font-ui);font-size:0.82rem;color:var(--ink-mid);line-height:1.45;}

/* ── SIDEBAR ────────────────────────────── */
#sidebar{
  position:fixed;top:calc(var(--topbar-h) + var(--goalbar-h));left:0;
  width:var(--sidebar-w);bottom:0;overflow-y:auto;
  background:#F7F9FC;border-right:1px solid var(--rule);
  padding:1rem 0;z-index:200;
}
.nav-section{
  padding:.2rem 1.1rem;font-family:var(--font-ui);font-size:.7rem;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;color:var(--ink-lt);margin-top:.7rem;
}
.nav-item{
  display:flex;align-items:center;gap:.5rem;padding:.35rem 1.1rem;
  text-decoration:none;font-family:var(--font-ui);font-size:.8rem;color:var(--ink-mid);
  border-left:3px solid transparent;cursor:pointer;transition:background .12s,color .12s;
}
.nav-item:hover{background:#EAF0F8;color:var(--ink);}
.nav-item.active{background:var(--ce-lt);color:var(--ce-navy);border-left-color:var(--ce-blue);font-weight:600;}
.nav-dot{width:7px;height:7px;border-radius:50%;background:var(--rule);flex-shrink:0;transition:background .2s;}
.nav-item.done .nav-dot{background:var(--ce-teal);}
.nav-item.active .nav-dot{background:var(--ce-blue);}

/* ── MAIN ───────────────────────────────── */
#main{
  margin-left:var(--sidebar-offset);
  padding-top:calc(var(--topbar-h) + var(--goalbar-h));
  min-height:100vh;display:flex;flex-direction:column;align-items:center;
  padding-bottom:6rem;
}
#main ul, #main ol{/* margin-left: 1.4rem; */padding-left: 1.8rem;}
#main ul li, #main ol li{margin-bottom:.3rem;}

/* ── CHAPTER HERO ───────────────────────── */
.ch-hero{
  width:100%;background:linear-gradient(135deg,var(--ce-dark) 0%,var(--ce-navy) 55%,var(--ce-mid) 100%);
  position:relative;overflow:hidden;padding:2.5rem 2.5rem 3.5rem;
  display:flex;flex-direction:column;gap:1rem;
}
/* decorative hexagons */
.ch-hero::before{
  content:'';position:absolute;right:-60px;top:-60px;width:280px;height:280px;
  background:url("data:image/svg+xml,%3Csvg viewBox='0 0 100 115' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolygon points='50,5 95,27.5 95,87.5 50,110 5,87.5 5,27.5' fill='none' stroke='rgba(9,174,150,0.25)' stroke-width='2'/%3E%3C/svg%3E") center/contain no-repeat;
  opacity:.6;
}
.ch-hero::after{
  content:'';position:absolute;right:80px;bottom:-40px;width:180px;height:200px;
  background:url("data:image/svg+xml,%3Csvg viewBox='0 0 100 115' xmlns='http://www.w3.org/2000/svg'%3E%3Cpolygon points='50,5 95,27.5 95,87.5 50,110 5,87.5 5,27.5' fill='none' stroke='rgba(255,255,255,0.12)' stroke-width='2'/%3E%3C/svg%3E") center/contain no-repeat;
}
.hero-tag{
  font-family:var(--font-ui);font-size:.7rem;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;color:var(--ce-teal);
}
.hero-title{
  font-family:var(--font-head);font-size:2rem;color:var(--ce-white);
  line-height:1.2;max-width:680px;
}
.hero-sub{font-family:var(--font-ui);font-size:.9rem;color:#9ABCD8;max-width:620px;line-height:1.5;}
/* wave divider */
.hero-wave{position:absolute;bottom:0;left:0;right:0;height:32px;overflow:hidden;}
.hero-wave svg{display:block;width:100%;height:100%;}

/* ── SECTION WRAPPER ────────────────────── */
.s-block{width:100%;max-width:860px;padding:0 1.5rem 0;}
/* Zorg dat sectie‑kop zichtbaar blijft onder fixed bars */
.s-block {
  scroll-margin-top: calc(var(--topbar-h) + var(--goalbar-h) + .9rem);
}

/* ── CONTENT CARD ───────────────────────── */
.ccard{
  background:var(--card);border:1px solid var(--rule);border-radius:8px;
  box-shadow:0 2px 8px rgba(4,59,125,.06);margin-bottom:1.8rem;overflow:hidden;
}
.ccard-head{
  background:var(--ce-navy);color:var(--ce-white);padding:.8rem 1.4rem;
  font-family:var(--font-head);font-size:1.05rem;
  display:flex;align-items:center;gap:.6rem;
}
.ccard-num{
  background:var(--ce-teal);color:var(--ce-white);font-family:var(--font-ui);
  font-size:.68rem;font-weight:700;padding:.12rem .42rem;border-radius:3px;letter-spacing:.05em;
}
.ccard-body{padding:1.4rem 1.6rem;}
.ccard-body p{margin-bottom:.85rem;clear:both;}
.ccard-body p:has(+ol), .ccard-body p:has(+ul){margin-bottom:0;}
.ccard-body p:last-child{margin-bottom:0;}
.ccard-body h3{
  font-family:var(--font-head);font-size:.98rem;color:var(--ce-blue);
  margin:1.3rem 0 .45rem;padding-bottom:.18rem;border-bottom:1px solid var(--rule);
}
.ccard-body em{color:var(--ink-mid);}

/* ── TABLES ─────────────────────────────── */
.ccard-body table{width:100%;border-collapse:collapse;font-size:.88rem;
  margin:1rem 0 1.2rem;font-family:var(--font-ui);}
.ccard-body th{background:var(--ce-navy);color:#fff;padding:.42rem .75rem;
  text-align:left;font-size:.78rem;font-weight:600;}
.ccard-body td{padding:.38rem .75rem;border-bottom:1px solid var(--rule);vertical-align:top;}
.ccard-body tr:nth-child(even) td{background:#F7F9FC;}

/* ── IMAGES ─────────────────────────────── */
.ccard-body img{max-width:100%;border-radius:4px;margin:0 .5rem 1rem 0;float:left;}
.ccard-body ul img:first-child {width: 2.7rem;margin: 0 0 0 -3rem;}
.ccard-body ul:has(img:first-child) {list-style-type: none;margin-left: 3rem !important;padding-left: 0 !important;}

/* Prevent normal list bullets from overlapping floated images.
   BFC (display:flow-root) clears the float for the box.
   padding-left instead of margin-left keeps the markers inside the
   border box, so they also clear the float. */
.ccard-body ul:not(:has(img:first-child)),
.ccard-body ol, .intro-card ul {
  display: flow-root;
  margin-left: 0;
  padding-left: 1.8rem;
}

/* ── CALLOUT BOXES ──────────────────────── */
.note{background:var(--gold-lt);border-left:3px solid var(--gold);
  padding:.65rem 1rem;font-size:.88rem;color:var(--ink-mid);margin:.9rem 0;
  border-radius:0 4px 4px 0;font-family:var(--font-ui);clear:both;}
.note > p:first-child:before{content: "ℹ ";font-weight:700;color:var(--gold);float: left;padding-right: 3px;}
.activity{background:#EAF5F0;border-left:3px solid var(--ce-teal);
  padding:.75rem 1rem;margin:.9rem 0;font-size:.88rem;
  color:var(--ink-mid);border-radius:0 4px 4px 0;font-family:var(--font-ui);}
.activity::before{content:"✏  Klasactiviteit — ";font-weight:700;color:var(--ce-teal);}

/* ── VIDEO EMBED ────────────────────────── */
.vid-wrap{overflow:hidden;
  box-shadow:0 2px 12px rgba(4,59,125,.12);}
.vid-wrap iframe{display:block;width:100%;aspect-ratio:16/9;border:none;}
.vid-caption{font-family:var(--font-ui);font-size:.78rem;color:var(--ink-lt);
  padding:.35rem .5rem;background:#F7F9FC;border:1px solid var(--rule);
  border-top:none;border-radius:0 0 6px 6px;}

/* ── INTRO section ──────────────────────── */
.intro-card{background:var(--ce-lt);border:1px solid #B8D0EC;border-radius:8px;
  padding:1.4rem 1.6rem;margin-bottom:1.8rem;}
.intro-card h2{font-family:var(--font-head);font-size:1.15rem;color:var(--ce-navy);
  margin-bottom:.7rem;}
.intro-card p{font-family:var(--font-ui);font-size:.92rem;color:var(--ink-mid);
  margin-bottom:.7rem;line-height:1.6;}

/* ── LEERDOELEN LIST ────────────────────── */
.leerdoelen-card{background:var(--ce-navy);border-radius:8px;
  padding:1.4rem 1.6rem;margin-bottom:2rem;color:var(--ce-white);}
.leerdoelen-card h2{font-family:var(--font-head);font-size:1.05rem;
  color:var(--ce-teal);margin-bottom:.9rem;letter-spacing:.02em;}
.leerdoelen-list{list-style:none;display:flex;flex-direction:column;gap:.55rem;padding-left: 0 !important;}
.leerdoelen-list li{
  display:flex;align-items:flex-start;gap:.7rem;
  font-family:var(--font-ui);font-size:.88rem;color:#C8DAEE;line-height:1.5;
}
.ld-num{
  flex-shrink:0;width:1.6rem;height:1.6rem;border-radius:50%;
  background:var(--ce-teal);color:var(--ce-dark);font-weight:700;
  font-size:.72rem;display:flex;align-items:center;justify-content:center;
  margin-top:.05rem;
}

/* ── CAESAR DEMO ────────────────────────── */
.caesar-tool{background:#F2F4F8;border:1px solid var(--rule);border-radius:6px;
  padding:1rem 1.2rem;margin:.9rem 0;font-family:var(--font-ui);}
.caesar-tool label{display:block;font-size:.78rem;color:var(--ink-lt);
  margin-bottom:.2rem;font-weight:600;}
.caesar-tool input[type=text]{width:100%;padding:.38rem .65rem;border:1px solid var(--rule);
  border-radius:4px;font-family:var(--font-mono);font-size:.98rem;color:var(--ink);
  background:#fff;margin-bottom:.7rem;text-transform:uppercase;}
.c-row{display:flex;gap:.8rem;align-items:center;margin-bottom:.7rem;}
.c-row input[type=range]{flex:1;accent-color:var(--ce-blue);}
.c-ndisplay{font-family:var(--font-mono);font-size:1.1rem;color:var(--ce-blue);
  font-weight:700;min-width:2rem;text-align:center;}
.cipher-out{background:var(--ce-dark);color:#62C8D8;font-family:var(--font-mono);
  font-size:1rem;padding:.45rem .8rem;border-radius:4px;letter-spacing:.12em;
  min-height:2.1rem;word-break:break-all;}

/* ── POLYBIUS ───────────────────────────── */
.pb-grid{display:inline-grid;grid-template-columns:repeat(6,2.1rem);
  gap:2px;font-family:var(--font-mono);font-size:.82rem;margin:.8rem 0;}
.pb-cell{width:2.1rem;height:2.1rem;display:flex;align-items:center;
  justify-content:center;border:1px solid var(--rule);background:#fff;}
.pb-hdr{background:var(--ce-navy);color:#fff;font-weight:700;font-family:var(--font-ui);}

/* ── EXERCISE ZONE ──────────────────────── */
.ex-zone{
  background:#F7F9FC;border-top:2px solid var(--ce-teal);
  padding:1.2rem 1.6rem 1.4rem;
  clear: both;
}
.ex-label{font-family:var(--font-ui);font-size:.68rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;color:var(--ce-blue);margin-bottom:.45rem;}
.ex-q{font-family:var(--font-body);font-size:.96rem;color:var(--ink);
  margin-bottom:.9rem;line-height:1.65;}

/* MC buttons */
.mc-list{list-style:none;display:flex;flex-direction:column;gap:.35rem;padding-left: 0 !important;}
.mc-btn{
  width:100%;text-align:left;background:#fff;border:1px solid var(--rule);
  border-radius:4px;padding:.48rem .85rem;font-family:var(--font-body);font-size:.92rem;
  cursor:pointer;color:var(--ink);display:flex;align-items:center;gap:.5rem;
  transition:background .1s,border-color .1s;
}
.mc-btn::before{
  content:attr(data-letter);font-family:var(--font-ui);font-size:.7rem;font-weight:700;
  color:var(--ink-lt);background:#F2F4F8;border:1px solid var(--rule);border-radius:3px;
  padding:0 .32rem;min-width:1.35rem;text-align:center;flex-shrink:0;
}
.mc-btn:hover:not(:disabled){background:#EBF2FB;border-color:#90AED0;}
.mc-btn.sel{background:#DCEAF8;border-color:var(--ce-blue);}
.mc-btn.sel::before{background:var(--ce-blue);color:#fff;border-color:var(--ce-blue);}
.mc-btn.rev-ok{background:var(--ok-lt);border-color:var(--ok);color:var(--ok);}
.mc-btn.rev-ok::before{background:var(--ok);color:#fff;border-color:var(--ok);}
.mc-btn.rev-err{background:var(--err-lt);border-color:var(--err);color:var(--err);}
.mc-btn.rev-err::before{background:var(--err);color:#fff;border-color:var(--err);}
.mc-btn:disabled{cursor:default;}

/* T/F */
.tf-row{display:flex;gap:.55rem;}
.tf-btn{flex:1;padding:.52rem;border-radius:4px;border:1px solid var(--rule);
  background:#fff;font-family:var(--font-ui);font-size:.9rem;cursor:pointer;
  color:var(--ink);font-weight:500;transition:background .1s;}
.tf-btn:hover:not(:disabled){background:#EBF2FB;}
.tf-btn.sel{background:#DCEAF8;border-color:var(--ce-blue);color:var(--ce-blue);font-weight:700;}
.tf-btn.rev-ok{background:var(--ok-lt);border-color:var(--ok);color:var(--ok);font-weight:700;}
.tf-btn.rev-err{background:var(--err-lt);border-color:var(--err);color:var(--err);font-weight:700;}
.tf-btn:disabled{cursor:default;}

/* FIB */
.fib-row{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;}
.fib-input{font-family:var(--font-body);font-size:.94rem;padding:.38rem .62rem;
  border:1px solid var(--rule);border-radius:4px;min-width:170px;background:#fff;color:var(--ink);}
.fib-input.rev-ok{border-color:var(--ok);background:var(--ok-lt);}
.fib-input.rev-err{border-color:var(--err);background:var(--err-lt);}

/* Match */


/* Match exercise: basis (desktop behoudt layout) */
.match-list {
  display: flex;
  flex-direction: column;
  gap: .6rem;
}

.match-row {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: .75rem;
}

.match-label {
  font-family: var(--font-ui);
  font-size: .86rem;
  color: var(--ink-mid);
}

.match-sel {
  padding: .38rem .62rem;
  border: 1px solid var(--rule);
  border-radius: 4px;
  background: #fff;
  color: var(--ink);
  font-family: var(--font-ui);
  font-size: .94rem;
  margin-bottom: .7rem;
}

/* Order drag */
.order-list{list-style:none;display:flex;flex-direction:column;gap:.32rem;}
.order-item{
  display:flex;align-items:center;gap:.6rem;background:#fff;
  border:1px solid var(--rule);border-radius:4px;padding:.42rem .75rem;
  cursor:grab;font-size:.88rem;font-family:var(--font-ui);color:var(--ink-mid);
  touch-action:none;user-select:none;transition:box-shadow .1s,opacity .1s;
}
.order-item:active{cursor:grabbing;}
.order-item.dragging{opacity:.4;box-shadow:0 4px 14px rgba(0,0,0,.15);}
.order-item.rev-ok{background:var(--ok-lt);border-color:var(--ok);color:var(--ok);}
.order-item.rev-err{background:var(--err-lt);border-color:var(--err);color:var(--err);}
.drag-h{color:#bbb;font-size:1.1rem;flex-shrink:0;}

/* Check button */
.btn-check{
  margin-top:.85rem;padding:.48rem 1.3rem;background:var(--ce-blue);color:#fff;
  border:none;border-radius:4px;font-family:var(--font-ui);font-size:.86rem;
  font-weight:600;cursor:pointer;letter-spacing:.02em;
  transition:background .12s,transform .08s;
}
.btn-check:hover:not(:disabled){background:var(--ce-navy);transform:translateY(-1px);}
.btn-check:disabled{background:#8AAEC8;cursor:default;transform:none;}

/* Feedback */
.feedback{display:none;margin-top:.7rem;padding:.58rem .85rem;border-radius:4px;
  font-family:var(--font-ui);font-size:.84rem;line-height:1.5;}
.feedback.show{display:block;}
.feedback.ok{background:var(--ok-lt);color:var(--ok);border:1px solid #9DD4B5;}
.feedback.err{background:var(--err-lt);color:var(--err);border:1px solid #F0AAAA;}
.feedback-answer{margin-top:.35rem;padding:.45rem .7rem;background:rgba(0,0,0,.05);
  border-radius:3px;font-style:italic;}

/* ── MULTI EXERCISE ─────────────────────── */
.multi-ex .multi-items{display:flex;flex-direction:column;gap:.75rem;}
.multi-item{background:#fff;border:1px solid var(--rule);border-radius:4px;padding:.75rem 1rem;}
.multi-item-q{font-size:.9rem;color:var(--ink);margin-bottom:.55rem;line-height:1.55;}
.sub-fb{display:none;margin-top:.4rem;padding:.28rem .55rem;border-radius:3px;
  font-size:.82rem;font-family:var(--font-ui);}
.sub-fb.show{display:block;}
.sub-fb.ok{background:var(--ok-lt);color:var(--ok);border:1px solid #9DD4B5;}
.sub-fb.err{background:var(--err-lt);color:var(--err);border:1px solid #F0AAAA;}
.fib-item{display:flex;flex-direction:column;gap:.3rem;}
.fib-sub-label{font-size:.88rem;color:var(--ink-mid);font-family:var(--font-ui);}

/* ── SCORE CARD ─────────────────────────── */
.score-card{background:var(--ce-navy);border-radius:8px;padding:1.4rem 1.6rem;
  margin-bottom:3rem;color:#fff;}
.score-card h3{font-family:var(--font-head);font-size:1.05rem;color:var(--ce-teal);margin-bottom:.65rem;}
.sc-track{height:10px;background:#0D2F5A;border-radius:5px;overflow:hidden;margin:.4rem 0 .8rem;}
.sc-fill{height:100%;background:var(--ce-teal);border-radius:5px;width:0%;transition:width .6s ease;}
.sc-text{font-family:var(--font-ui);font-size:.88rem;color:#9ABCD8;}

/* ── CE FOOTER WAVE ─────────────────────── */
.ce-footer-wave{background:var(--ce-dark);color:#9ABCD8;
  font-family:var(--font-ui);font-size:.75rem;padding:.8rem 1.5rem;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;}
.ce-footer-wave a{color:var(--ce-teal);text-decoration:none;}
.ce-footer-wave a:hover{text-decoration:underline;}

/* Footer mag niet onder vaste zijbalk vallen */
.ce-footer-wave,
.ce-footer-wave .footer-inner {
  padding-left: calc(1.5rem + var(--sidebar-offset));
}

/* Tabellen responsief maken binnen ccard */
.ccard-body table {
  display: block;
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
/* Form elementen nooit breder dan de card */
.ccard-body input,
.ccard-body textarea,
.ccard-body select {
  max-width: 100%;
  box-sizing: border-box;
}
