/* First Case theme · main stylesheet
   Converted from Slaven's design artboards (desktop .ab-d = source of truth,
   mobile .ab-m artboard implemented as the media queries at the end).
   Tokens live in tokens.css. */

*{box-sizing:border-box;}
body{margin:0;color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased;}
a{color:inherit;text-decoration:none;}
h1, h2, h3, h4, h5{margin:0;font-weight:600;letter-spacing:-.02em;}
p{margin:0;}
.lane{display:flex;gap:60px;align-items:flex-start;}
.col{flex:0 0 auto;}
.ab{background:var(--bg);border:1px solid var(--line-2);overflow:hidden;box-shadow:0 40px 90px -50px rgba(0,0,0,.6);}
.mono{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);}
.rule{height:1px;background:var(--line);border:0;margin:0;}
.btn{display:inline-flex;align-items:center;gap:8px;font-family:inherit;font-size:14px;font-weight:500;padding:11px 18px;border-radius:8px;border:1px solid transparent;cursor:pointer;white-space:nowrap;transition:background .26s ease,border-color .26s ease,color .26s ease,box-shadow .26s ease;}
.btn-primary{background:var(--accent);color:#fff;}
.btn-ghost{color:var(--ink);border-color:var(--line-2);background:var(--paper);}
.btn .ar{display:inline-block;transition:transform .28s cubic-bezier(.2,.7,.2,1);}
.btn:hover .ar{transform:translateX(4px);}
.btn-primary:hover{background:var(--accent-2,#3b54c9);box-shadow:0 0 0 4px rgba(31,95,214,.22),0 0 22px rgba(31,95,214,.5);}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent);box-shadow:0 0 0 4px rgba(31,95,214,.14);}
.wrap{max-width:none;margin:0;padding:0 40px;}
.secnum{display:flex;align-items:center;gap:12px;}
.secnum .bar{width:26px;height:1px;background:var(--ink-3);}
.sechead{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;margin-bottom:38px;}
.sechead .lhs{display:flex;flex-direction:column;gap:0;}
.sechead h2{font-size:38px;letter-spacing:-.03em;max-width:28ch;}
.sechead .intro{font-size:16px;color:var(--ink-2);line-height:1.6;max-width:72ch;margin-top:2px;}
.block{padding:var(--sec-y) 0;position:relative;isolation:isolate;}
.block::before{content:"";position:absolute;top:0;left:0;right:0;height:560px;z-index:-1;pointer-events:none;
    }
.util{border-bottom:1px solid var(--line);background:var(--bg);}
.util .wrap{display:flex;align-items:center;justify-content:space-between;height:38px;}
.util .mono{display:flex;align-items:center;gap:8px;}
.util .dot{width:6px;height:6px;border-radius:50%;background:#3a9d6a;box-shadow:0 0 0 3px rgba(58,157,106,.16);}
.util .right{display:flex;gap:22px;}
.head{border-bottom:1px solid var(--line);background:var(--bg);}
.head .wrap{display:flex;align-items:center;justify-content:space-between;height:66px;}
.flag{display:inline-flex;align-items:center;gap:7px;cursor:pointer;background:none;border:0;padding:0;}
.flag .nl{width:22px;height:15px;border-radius:3px;display:block;background:linear-gradient(#ae1c28 0 33.3%,#fff 33.3% 66.6%,#21468b 66.6% 100%);box-shadow:0 0 0 1px rgba(255,255,255,.35);}
.flag .lng{font-family:var(--mono);font-size:10px;letter-spacing:.1em;color:rgba(255,255,255,.7);}
.flag .en{width:22px;height:15px;border-radius:3px;display:block;box-shadow:0 0 0 1px rgba(255,255,255,.35);background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 60 30'%3E%3Crect width='60' height='30' fill='%23012169'/%3E%3Cpath d='M0,0 L60,30 M60,0 L0,30' stroke='%23fff' stroke-width='6'/%3E%3Cpath d='M0,0 L60,30 M60,0 L0,30' stroke='%23C8102E' stroke-width='4'/%3E%3Cpath d='M30,0 V30 M0,15 H60' stroke='%23fff' stroke-width='10'/%3E%3Cpath d='M30,0 V30 M0,15 H60' stroke='%23C8102E' stroke-width='6'/%3E%3C/svg%3E") center/100% 100% no-repeat;}
.flag-wrap{position:relative;}
.flag{padding:6px 8px;border-radius:8px;}
.flag:hover{background:rgba(255,255,255,.08);}
.flag.flag-static{cursor:default;}
.flag.flag-static:hover{background:none;}
.flag .caret{font-size:9px;color:rgba(255,255,255,.6);transition:transform .15s;}
.flag-wrap.open .caret{transform:rotate(180deg);}
.flag-menu{position:absolute;top:calc(100% + 8px);right:0;min-width:176px;background:rgba(18,22,30,.96);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.16);border-radius:11px;padding:6px;display:none;flex-direction:column;gap:2px;z-index:30;box-shadow:0 20px 40px -16px rgba(0,0,0,.6);}
.flag-wrap.open .flag-menu{display:flex;}
.flag-menu button{display:flex;align-items:center;gap:11px;padding:10px 11px;border:0;background:none;color:rgba(255,255,255,.82);font-family:var(--sans);font-size:13.5px;border-radius:8px;cursor:pointer;text-align:left;}
.flag-menu button:hover{background:rgba(255,255,255,.1);color:#fff;}
.flag-menu button[aria-current="true"]{color:#fff;background:rgba(255,255,255,.06);}
.fl{width:22px;height:15px;border-radius:3px;display:block;box-shadow:0 0 0 1px rgba(255,255,255,.3);flex:none;}
.fl.nl{background:linear-gradient(#ae1c28 0 33.3%,#fff 33.3% 66.6%,#21468b 66.6% 100%);}
.fl.en{background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 60 30'%3E%3Crect width='60' height='30' fill='%23012169'/%3E%3Cpath d='M0,0 L60,30 M60,0 L0,30' stroke='%23fff' stroke-width='6'/%3E%3Cpath d='M0,0 L60,30 M60,0 L0,30' stroke='%23C8102E' stroke-width='4'/%3E%3Cpath d='M30,0 V30 M0,15 H60' stroke='%23fff' stroke-width='10'/%3E%3Cpath d='M30,0 V30 M0,15 H60' stroke='%23C8102E' stroke-width='6'/%3E%3C/svg%3E") center/100% 100% no-repeat;}
.brand{display:flex;align-items:baseline;gap:10px;white-space:nowrap;}
.brand b{font-size:19px;font-weight:700;letter-spacing:-.04em;}
.brand .mono{font-size:9.5px;}
nav.links{display:flex;gap:30px;font-size:14.5px;color:var(--ink-2);}
nav.links a.active{color:var(--ink);}
.nav-actions{display:flex;align-items:center;gap:14px;}
body{position:relative;background:transparent;}/* body MUST stay transparent: it is positioned (position:relative) so an opaque body bg paints OVER the z-index:-1 aurora .bg and hides it (whole page goes flat). The iOS safe-area bands instead show the html CANVAS background, set per page in header.php. */
.topbar.over{position:absolute;top:22px;left:50%;transform:translateX(-50%);width:calc(100% - 80px);max-width:1440px;z-index:6;}
.topbar.over .head{background:linear-gradient(180deg,rgba(255,255,255,.10),rgba(255,255,255,.02) 55%),rgba(16,21,30,.38);backdrop-filter:blur(22px) saturate(1.6);-webkit-backdrop-filter:blur(22px) saturate(1.6);border:1px solid rgba(255,255,255,.22);border-radius:18px;box-shadow:inset 0 1px 0 rgba(255,255,255,.16),0 16px 40px -24px rgba(6,10,18,.75);}
.topbar.over nav.links{gap:16px;}
.topbar.over nav.links a{padding:9px 15px;border-radius:999px;transition:background .2s ease,color .2s ease;}
.topbar.over nav.links a:hover{background:rgba(255,255,255,.1);}
.topbar.over nav.links a.active{background:rgba(255,255,255,.14);}
.topbar.over .head .wrap{max-width:none;padding:0 22px 0 26px;height:62px;}
.topbar.over .brand b{color:#fff;}
.topbar.over .brand .mono{color:rgba(255,255,255,.58);}
.topbar.over nav.links{color:rgba(255,255,255,.82);}
.topbar.over nav.links a.active{color:#fff;}
.topbar.over .btn-ghost{background:rgba(255,255,255,.1);color:#fff;border-color:rgba(255,255,255,.32);}
.topbar.over .btn-ghost:hover{color:#cfe0ff;border-color:#7fb0ff;box-shadow:0 0 0 4px rgba(127,176,255,.2),0 0 18px rgba(127,176,255,.32);}
.hero{position:relative;height:884px;overflow:hidden;}
.hero video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;background:#11151c;}
.hero .scrim{position:absolute;inset:0;z-index:2;background:linear-gradient(90deg,rgba(12,14,18,.9),rgba(12,14,18,.5) 52%,rgba(12,14,18,.66));}
.hero .inner{position:absolute;inset:0;z-index:3;display:flex;flex-direction:column;justify-content:center;padding-top:80px;}
.hero .inner .wrap{width:100%;display:block;}
.hero .eyebrow{display:flex;align-items:center;gap:12px;}
.hero .eyebrow .bar{width:26px;height:1px;background:rgba(255,255,255,.45);}
.hero .eyebrow .mono{color:rgba(255,255,255,.72);;white-space:nowrap;}
/* live-ops hero: glass status pill + pulsing dot, technical grid overlay, big bold kop */
.hero-status{display:inline-flex;align-items:center;gap:11px;white-space:nowrap;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.7);border:1px solid rgba(255,255,255,.16);border-radius:999px;padding:7px 14px;background:rgba(10,14,20,.5);}
.hero-status .live{width:7px;height:7px;border-radius:50%;background:#3ac882;animation:fcpulse 2s ease-in-out infinite;}
@keyframes fcpulse{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(58,200,130,.5);}50%{opacity:.7;box-shadow:0 0 0 6px rgba(58,200,130,0);}}
.hero h1{font-size:88px;line-height:.96;letter-spacing:-.04em;font-weight:700;color:#fff;margin-top:22px;max-width:18ch;}
.hero h1 .rotate{color:#7fb0ff;transition:opacity .28s ease,transform .28s ease;}
.hero h1 .rotate.rot-block{display:block;}
.hero .lead{margin-top:24px;font-size:18px;line-height:1.55;color:rgba(255,255,255,.8);max-width:54ch;}
@media (prefers-reduced-motion:reduce){.hero-status .live{animation:none;}}
.hero .cta{display:flex;flex-wrap:wrap;gap:12px;margin-top:34px;}
.hero .btn-ghost{background:rgba(10,14,20,.42);backdrop-filter:blur(10px) saturate(1.3);-webkit-backdrop-filter:blur(10px) saturate(1.3);color:#fff;border-color:rgba(255,255,255,.34);}
.hero .btn-ghost:hover{color:#cfe0ff;border-color:#7fb0ff;box-shadow:0 0 0 4px rgba(127,176,255,.2),0 0 20px rgba(127,176,255,.34);}
.hero .dot{width:7px;height:7px;border-radius:50%;background:#7fb0ff;box-shadow:0 0 8px #7fb0ff;}
.hero .badge{font-family:var(--mono);font-size:10px;color:#bcd4ff;padding:2px 6px;border:1px solid rgba(127,176,255,.4);border-radius:999px;}
.hero .meta{border-left:1px solid rgba(255,255,255,.2);padding-left:26px;display:flex;flex-direction:column;gap:22px;}
.hero .meta .k{font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.55);}
.hero .meta .v{font-size:14px;color:#fff;margin-top:5px;line-height:1.4;}
.hero .rec{position:absolute;z-index:4;bottom:18px;right:18px;display:none;}
.trust{background:transparent;}
.trust .wrap{display:flex;align-items:center;gap:0;height:84px;}
.trust .lbl{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);white-space:nowrap;padding-right:30px;}
.trust .marquee{flex:1;overflow:hidden;border-left:1px solid var(--line);position:relative;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);}
.trust .track{display:flex;width:max-content;animation:marq 22s ease-in-out infinite alternate;}
.trust .track span{padding:0 50px;font-weight:600;font-size:17px;letter-spacing:-.01em;color:var(--ink-2);white-space:nowrap;}
/* The "Vertrouwd door" bar now sits below the hero as a light block, so the base
   .trust style (light bg, dark text, bottom rule) applies. The former dark in-hero
   overrides (.hero .trust: glass bg, white text, absolute bottom) are removed. */
@keyframes marq{from{transform:translateX(0);}to{transform:translateX(-46%);}}
.svc{display:grid;grid-template-columns:repeat(6,1fr);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--paper);}
.tile{position:relative;padding:30px;border-right:1px solid var(--line);border-top:1px solid var(--line);display:flex;flex-direction:column;color:inherit;}
.tile .ix{font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--ink-3);}
.tile h3{margin-top:12px;letter-spacing:-.02em;}
.tile p{margin-top:10px;color:var(--ink-2);line-height:1.55;}
.tile .go{margin-top:auto;padding-top:18px;font-size:13px;font-weight:500;color:var(--accent);display:flex;align-items:center;gap:7px;}
.tile .chip{position:absolute;top:30px;right:30px;display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);border:1px solid var(--line-2);border-radius:999px;padding:5px 10px;background:var(--paper);}
.tile .chip .d{width:6px;height:6px;border-radius:50%;background:var(--accent);}
.tile .chip.kern{color:var(--ink);}
.tile .chip.kern .d{background:var(--ink);}
.tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:16px;}
.tags span{font-family:var(--mono);font-size:10px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-2);border:1px solid var(--line);border-radius:5px;padding:4px 8px;}
.t-ups{grid-column:span 4;grid-row:1;border-top:0;display:grid;grid-template-columns:1.05fr 1fr;gap:30px;min-height:360px;}
.t-mon{grid-column:span 2;grid-row:1;border-top:0;border-right:0;min-height:360px;}
.t-mnt{grid-column:span 2;}
.t-load{grid-column:span 2;}
.t-clean{grid-column:span 2;border-right:0;background:var(--bg-2);}
.t-ups .frame{position:relative;border:1px solid var(--line);overflow:hidden;min-height:280px;}
.t-ups .colL{display:flex;flex-direction:column;}
.prod{display:grid;grid-template-columns:1.3fr 1fr;gap:32px;align-items:flex-start;}
.prod .frame{position:relative;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;height:380px;background:var(--paper);}
.prod .list{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--paper);}
.prod .list a{display:grid;grid-template-columns:170px 1fr 20px;gap:16px;padding:16px 18px;border-top:1px solid var(--line);align-items:center;}
.prod .list a:first-child{border-top:0;}
.prod .list .k{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink);}
.prod .list .v{font-size:13.5px;color:var(--ink-2);}
.prod .list .ar{color:var(--ink-3);}
.prod .pintro{font-size:15px;color:var(--ink-2);line-height:1.6;margin-bottom:22px;}
.prin{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1px;border-radius:16px;overflow:hidden;box-shadow:0 30px 62px -40px rgba(30,42,64,.5);background:#dfe2e7;}
.prin .p{padding:26px 22px 22px;background:linear-gradient(165deg,#fafbfc 0%,#ebedf0 100%);display:flex;flex-direction:column;transition:background .3s ease;}
.prin .p:hover{background:linear-gradient(165deg,#ffffff 0%,#eef2f7 100%);}
.prin .p .ix{font-family:var(--mono);font-size:30px;font-weight:500;letter-spacing:-.03em;color:var(--line-2);line-height:1;}
.prin .p h4{margin-top:16px;font-size:18px;letter-spacing:-.015em;}
.prin .p p{margin-top:8px;font-size:13.5px;color:var(--ink-2);line-height:1.6;}
.cases{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.case .frame{position:relative;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;height:240px;background:var(--paper);}
.case .meta{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);margin-top:16px;}
.case h4{margin-top:8px;font-size:19px;letter-spacing:-.02em;}
.werken{background:radial-gradient(920px 480px at 84% -16%,rgba(28,41,66,1),rgba(14,17,24,1) 72%);color:#fff;border-radius:18px;overflow:hidden;padding:48px 46px 40px;box-shadow:0 44px 90px -46px rgba(14,17,24,.75);}
.werken .wk-top{display:flex;align-items:flex-end;justify-content:space-between;gap:40px;margin-bottom:34px;padding:0;}
.werken .wk-top .l{display:flex;flex-direction:column;max-width:780px;}
.werken .secnum .bar{background:rgba(255,255,255,.4);}
.werken .secnum .mono{color:rgba(255,255,255,.5);}
.werken h2{font-size:40px;letter-spacing:-.03em;color:#fff;max-width:22ch;}
.werken .sub{margin-top:18px;color:#9aa3b2;font-size:16px;line-height:1.6;max-width:64ch;}
.werken .wk-top .r{display:flex;flex-direction:column;align-items:flex-end;gap:14px;flex:none;}
.werken .wk-chip{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:#9cc0ff;border:1px solid rgba(127,176,255,.36);border-radius:999px;padding:6px 12px;background:rgba(127,176,255,.08);}
.werken .wk-chip .d{width:7px;height:7px;border-radius:50%;background:#7fb0ff;box-shadow:0 0 8px #7fb0ff;}
.werken .wk-idx{border-top:1px solid rgba(255,255,255,.12);}
.werken .er{display:grid;grid-template-columns:160px 1fr 360px;gap:40px;align-items:center;padding:24px 14px 24px 4px;border-bottom:1px solid rgba(255,255,255,.1);text-decoration:none;color:inherit;border-radius:10px;transition:background .28s;}
.werken .er .big{font-family:var(--mono);font-size:80px;font-weight:500;line-height:.8;letter-spacing:-.04em;color:transparent;-webkit-text-stroke:1.5px rgba(127,176,255,.85);transition:color .3s,-webkit-text-stroke .3s,text-shadow .3s;}
.werken .er h5{font-size:26px;font-weight:600;letter-spacing:-.02em;color:#fff;line-height:1.12;}
.werken .er .proof{margin-top:9px;font-family:var(--mono);font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:#9cc0ff;}
.werken .er .desc{font-size:14px;color:#9aa3b2;line-height:1.55;}
.werken .er:hover{background:linear-gradient(90deg,rgba(31,95,214,.18),transparent);}
.werken .er:hover .big{color:#7fb0ff;-webkit-text-stroke:0;text-shadow:0 0 26px rgba(127,176,255,.6);}
.werken .btn-light{background:#fff;color:var(--ink);}
.werken .btn-light:hover{background:#fff;color:var(--ink);box-shadow:0 0 0 4px rgba(127,176,255,.22),0 0 20px rgba(127,176,255,.3);}
.eod{display:flex;align-items:center;justify-content:space-between;gap:30px;border:1px solid var(--line);border-radius:var(--r);background:var(--paper);padding:28px 34px;margin-top:20px;}
.eod .lbl{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);}
.eod .lbl .d{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 3px rgba(31,95,214,.14);}
.eod h3{margin-top:12px;font-size:22px;letter-spacing:-.02em;}
.eod .sub{margin-top:6px;color:var(--ink-2);font-size:14px;}
.eod .phone{font-family:var(--mono);font-size:26px;font-weight:500;letter-spacing:-.01em;white-space:nowrap;}
footer{background:linear-gradient(160deg,rgba(35,39,47,1) 0%,rgba(26,29,36,1) 100%);color:#fff;border-top:0;padding:60px 0 calc(38px + env(safe-area-inset-bottom));margin-top:var(--sec-y);}/* bleed the dark footer into the iOS bottom safe area (home indicator) so that band is the real footer, not a strip. env()=0 on desktop → unchanged. */
.foot{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr 1fr;gap:30px;}
.foot h5{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:16px;font-weight:500;}
.foot a, .foot .li{display:block;font-size:14px;color:rgba(255,255,255,.72);padding:5px 0;}
.foot a:hover{color:#fff;}
.foot .brand b{font-size:18px;color:#fff;}
.foot .desc{font-size:13.5px;color:rgba(255,255,255,.6);line-height:1.6;margin-top:12px;max-width:34ch;}
.foot-base{display:flex;justify-content:space-between;align-items:center;margin-top:44px;padding-top:22px;border-top:1px solid rgba(255,255,255,.12);}
.foot-base .mono{color:rgba(255,255,255,.5);}
.foot-base a{transition:color .15s ease;}
.foot-base a:hover{color:#fff;}
.m-bar{display:flex;align-items:center;justify-content:space-between;height:56px;padding:0 20px;border-bottom:1px solid var(--line);background:var(--bg);}
.m-bar .brand{display:flex;align-items:baseline;gap:8px;}
.m-bar .brand b{font-size:17px;font-weight:700;letter-spacing:-.04em;white-space:nowrap;}
.m-bar .brand .mono{font-size:8px;}
.m-bar .menu{display:flex;flex-direction:column;gap:4px;cursor:pointer;padding:0;border:0;background:none;-webkit-appearance:none;appearance:none;}
.m-bar .menu span{width:20px;height:1.5px;background:var(--ink);display:block;transition:transform .3s ease,opacity .2s ease;}
.m-menu{position:absolute;top:0;left:0;right:0;height:782px;z-index:20;color:#fff;display:none;flex-direction:column;
    background:radial-gradient(520px 360px at 82% -4%,rgba(31,95,214,.34),transparent 60%),linear-gradient(165deg,#171b25 0%,#0e1118 100%);}
@keyframes mMenuIn{from{opacity:0;transform:translateY(-10px);}to{opacity:1;transform:none;}}
@keyframes mLinkIn{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:none;}}
.m-menu .m-menu-bar{display:flex;align-items:center;justify-content:space-between;padding:25px 20px 0;}
.m-menu .m-menu-bar .brand b{font-size:17px;font-weight:700;letter-spacing:-.04em;color:#fff;}
.m-menu .m-close{appearance:none;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.06);width:38px;height:38px;border-radius:10px;position:relative;cursor:pointer;flex:none;}
.m-menu .m-close span{position:absolute;top:50%;left:50%;width:15px;height:1.5px;background:#fff;}
.m-menu .m-close span:nth-child(1){transform:translate(-50%,-50%) rotate(45deg);}
.m-menu .m-close span:nth-child(2){transform:translate(-50%,-50%) rotate(-45deg);}
.m-menu .m-menu-eyebrow{font-family:var(--mono);font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.42);padding:30px 24px 0;}
.m-menu nav{display:flex;flex-direction:column;padding:8px 24px 0;}
.m-menu nav a{display:flex;align-items:center;gap:14px;padding:16px 0;border-bottom:1px solid rgba(255,255,255,.1);transition:color .15s ease;}
.m-menu nav a .ix{font-family:var(--mono);font-size:11px;color:rgba(127,176,255,.85);width:20px;flex:none;}
.m-menu nav a .lbl{font-size:25px;letter-spacing:-.025em;font-weight:500;flex:1;}
.m-menu nav a .badge{font-family:var(--mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:#9cc0ff;border:1px solid rgba(127,176,255,.4);border-radius:999px;padding:3px 8px;white-space:nowrap;flex:none;}
.m-menu nav a .ar{color:rgba(255,255,255,.38);font-size:17px;}
.m-menu nav a:active{color:#9cc0ff;}
.m-menu .m-menu-foot{margin-top:24px;padding:0 24px 30px;display:flex;flex-direction:column;gap:18px;}
.m-menu .m-menu-cta{display:flex;align-items:center;justify-content:center;gap:8px;background:#fff;color:var(--ink);font-size:15px;font-weight:600;border-radius:10px;padding:15px;}
.m-menu .m-menu-meta{display:flex;align-items:flex-end;justify-content:space-between;}
.m-menu .sd{font-family:var(--mono);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.5);line-height:1.9;}
.m-menu .sd b{display:block;font-size:14px;color:#fff;letter-spacing:0;text-transform:none;}
.m-menu .sd .d{display:inline-block;width:6px;height:6px;border-radius:50%;background:#3a9d6a;margin-right:6px;box-shadow:0 0 0 3px rgba(58,157,106,.18);}
.m-menu .m-flag2{display:flex;align-items:center;gap:7px;font-family:var(--mono);font-size:11px;color:rgba(255,255,255,.7);}
.m-menu .m-flag2 .nl{width:20px;height:14px;border-radius:3px;display:block;background:linear-gradient(#ae1c28 0 33.3%,#fff 33.3% 66.6%,#21468b 66.6% 100%);box-shadow:0 0 0 1px rgba(255,255,255,.35);}
.m-hero{position:relative;min-height:600px;overflow:hidden;background:#11151c;padding-top:78px;padding-bottom:8px;}
.m-hero video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.m-hero .scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(12,14,18,.66),rgba(12,14,18,.92));}
.m-hero .rec{position:absolute;top:96px;right:13px;z-index:3;}
.m-hero .in{position:relative;z-index:2;padding:30px 20px 28px;}
.m-hero .eyebrow{display:flex;gap:10px;align-items:center;}
.m-hero .eyebrow .bar{width:20px;height:1px;background:rgba(255,255,255,.4);}
.m-hero .eyebrow .mono{font-size:10px;letter-spacing:.1em;color:rgba(255,255,255,.7);;white-space:nowrap;}
.m-hero h1{color:#fff;font-size:34px;line-height:1.0;letter-spacing:-.035em;margin-top:14px;}
.m-hero .lead{color:rgba(255,255,255,.78);font-size:13px;line-height:1.5;margin-top:14px;}
.m-hero .cta{display:flex;flex-direction:column;gap:8px;margin-top:22px;}
.m-hero .btn{justify-content:center;width:100%;}
.m-hero .btn-ghost{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.28);}
.m-hero .dot{width:6px;height:6px;border-radius:50%;background:#7fb0ff;box-shadow:0 0 6px #7fb0ff;}
.m-hero .badge{font-family:var(--mono);font-size:10px;color:#bcd4ff;padding:1px 6px;border:1px solid rgba(127,176,255,.4);border-radius:999px;}
.m-hero-meta{display:grid;grid-template-columns:1fr 1fr;gap:18px 16px;margin-top:30px;padding-top:24px;border-top:1px solid rgba(255,255,255,.16);}
.m-hero-meta .k{font-family:var(--mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.55);}
.m-hero-meta .v{font-size:13px;margin-top:4px;color:#fff;line-height:1.4;}
.m-meta{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:20px 20px;border-bottom:1px solid var(--line);background:var(--bg-2);}
.m-meta .k{font-family:var(--mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);}
.m-meta .v{font-size:13px;margin-top:4px;color:var(--ink);line-height:1.4;}
.m-sec{padding:var(--sec-y) 20px;position:relative;isolation:isolate;}
.m-sec.alt{background:transparent;border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.m-trust{padding:18px 0 18px 20px;border-bottom:1px solid var(--line);overflow:hidden;}
.m-trust .lbl{font-family:var(--mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);}
.m-trust .marquee{overflow:hidden;margin-top:12px;-webkit-mask-image:linear-gradient(90deg,#000 85%,transparent);mask-image:linear-gradient(90deg,#000 85%,transparent);}
.m-trust .track{display:flex;width:max-content;animation:marq 20s ease-in-out infinite alternate;}
.m-trust .track span{padding-right:30px;font-weight:600;font-size:14px;color:var(--ink-2);white-space:nowrap;letter-spacing:-.01em;}
.m-secnum{display:flex;align-items:center;gap:10px;}
.m-secnum .bar{width:20px;height:1px;background:var(--ink-3);}
.m-secnum .mono{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);}
.m-h2{font-size:24px;letter-spacing:-.03em;margin-top:12px;}
.m-intro{font-size:13.5px;color:var(--ink-2);line-height:1.55;margin-top:10px;}
.m-list{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--paper);margin-top:18px;}
.m-card{padding:20px;border-top:1px solid var(--line);}
.m-card:first-child{border-top:0;}
.m-card .top{display:flex;align-items:center;justify-content:space-between;}
.m-card .ix{font-family:var(--mono);font-size:10px;letter-spacing:.08em;color:var(--ink-3);}
.m-card h3{font-size:20px;letter-spacing:-.02em;margin-top:10px;}
.m-card p{font-size:13px;color:var(--ink-2);line-height:1.5;margin-top:8px;}
.m-chip{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);border:1px solid var(--line-2);border-radius:999px;padding:4px 9px;}
.m-chip .d{width:5px;height:5px;border-radius:50%;background:var(--accent);}
.m-chip.kern{color:var(--ink);}
.m-chip.kern .d{background:var(--ink);}
.m-frame{position:relative;border:1px solid var(--line);overflow:hidden;height:160px;margin-top:14px;}
.m-tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:12px;}
.m-tags span{font-family:var(--mono);font-size:9px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-2);border:1px solid var(--line);border-radius:4px;padding:3px 7px;}
.m-card.muted{background:var(--bg-2);}
.m-card.muted h3{color:var(--ink-2);}
.m-card .go{display:inline-flex;margin-top:12px;font-size:12px;font-weight:500;color:var(--accent);}
.m-prodlist{border:0;border-radius:14px;overflow:hidden;background:#dfe2e7;display:flex;flex-direction:column;gap:1px;margin-top:14px;box-shadow:0 18px 40px -30px rgba(30,42,64,.5);}
.m-prodlist a{display:block;padding:14px 15px;border-top:0;background:linear-gradient(165deg,#fafbfc 0%,#ebedf0 100%);}
.m-prodlist a:first-child{border-top:0;}
.m-prodlist .k{font-family:var(--mono);font-size:10px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink);}
.m-prodlist .v{font-size:12px;color:var(--ink-2);margin-top:3px;}
.m-prin{margin-top:16px;display:flex;flex-direction:column;gap:1px;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#dfe2e7;box-shadow:0 20px 44px -34px rgba(30,42,64,.5);}
.m-prin .p{padding:18px;background:linear-gradient(165deg,#fafbfc,#ebedf0);}
.m-prin .ix{font-family:var(--mono);font-size:24px;font-weight:500;letter-spacing:-.03em;color:var(--line-2);line-height:1;}
.m-prin h4{font-size:17px;margin-top:12px;letter-spacing:-.01em;font-weight:600;}
.m-prin p{font-size:13px;color:var(--ink-2);line-height:1.55;margin-top:8px;}
.m-seccta{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;margin-top:18px;background:var(--paper);border:1px solid var(--line-2);color:var(--ink);font-size:14px;font-weight:500;padding:13px;border-radius:8px;}
.m-seccta .ar{display:inline-block;}
.m-cases{display:flex;flex-direction:column;gap:18px;margin-top:18px;}
.m-case .m-frame{height:180px;}
.m-case .meta{font-family:var(--mono);font-size:10px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-3);margin-top:12px;}
.m-case h4{font-size:17px;margin-top:6px;letter-spacing:-.02em;}
.m-werken{background:radial-gradient(420px 300px at 8% 2%,rgba(31,95,214,.42),transparent 62%),radial-gradient(380px 320px at 100% 100%,rgba(60,120,230,.22),transparent 60%),linear-gradient(160deg,rgba(23,27,37,1) 0%,rgba(15,19,27,1) 100%);color:#fff;padding:30px 20px;}
.m-werken .m-secnum .bar{background:rgba(255,255,255,.4);}
.m-werken .m-secnum .mono{color:rgba(255,255,255,.6);}
.m-werken h2{color:#fff;font-size:24px;letter-spacing:-.02em;line-height:1.1;}
.m-werken .sub{color:#a8a49b;font-size:13px;line-height:1.6;margin-top:14px;}
.m-werken .btn-light{background:#fff;color:var(--ink);width:100%;justify-content:center;margin-top:14px;}
.m-werken .wk-chip{display:inline-flex;align-items:center;gap:8px;margin-top:18px;font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:#9cc0ff;border:1px solid rgba(127,176,255,.36);border-radius:999px;padding:5px 10px;background:rgba(127,176,255,.08);}
.m-werken .wk-chip .d{width:6px;height:6px;border-radius:50%;background:#7fb0ff;box-shadow:0 0 7px #7fb0ff;}
.m-werken .wk-idx{margin-top:24px;border-top:1px solid rgba(255,255,255,.12);}
.m-werken .mer{display:block;padding:18px 0;border-bottom:1px solid rgba(255,255,255,.1);text-decoration:none;color:inherit;}
.m-werken .mer .big{font-family:var(--mono);font-size:44px;font-weight:500;line-height:.8;letter-spacing:-.04em;color:transparent;-webkit-text-stroke:1.2px rgba(127,176,255,.85);}
.m-werken .mer h5{margin:12px 0 0;font-size:18px;font-weight:600;letter-spacing:-.015em;color:#fff;line-height:1.15;}
.m-werken .mer .proof{margin-top:8px;font-family:var(--mono);font-size:10px;letter-spacing:.04em;text-transform:uppercase;color:#9cc0ff;}
.m-werken .mer p{margin:10px 0 0;font-size:13px;color:#9aa3b2;line-height:1.5;}
.m-eod{padding:24px 22px;border-top:1px solid var(--line);background:var(--paper);}
.m-eod .lbl{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);}
.m-eod .lbl .d{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 3px rgba(31,95,214,.14);}
.m-eod h3{font-size:18px;margin-top:12px;letter-spacing:-.02em;}
.m-eod .phone{font-family:var(--mono);font-size:21px;font-weight:500;margin-top:10px;}
.m-eod .sub{font-size:12px;color:var(--ink-2);margin-top:4px;}
.m-foot{padding:34px 20px 26px;border-top:0;background:linear-gradient(160deg,#23272f 0%,#1a1d24 100%);color:#fff;}
.m-foot .brand b{font-size:17px;font-weight:700;letter-spacing:-.04em;color:#fff;}
.m-foot .desc{font-size:12px;color:rgba(255,255,255,.6);line-height:1.55;margin-top:10px;}
.m-foot .cols{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:22px;}
.m-foot h5{font-family:var(--mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:10px;}
.m-foot a, .m-foot .li{display:block;font-size:13px;color:rgba(255,255,255,.72);padding:4px 0;}
.m-foot .base{margin-top:22px;padding-top:16px;border-top:1px solid rgba(255,255,255,.12);font-family:var(--mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.5);display:flex;flex-direction:column;gap:6px;}
.svc{border:0;border-radius:16px;background:transparent;gap:1px;box-shadow:0 30px 62px -40px rgba(30,42,64,.5);overflow:hidden;}
.tile{border:0;background:linear-gradient(165deg,#fafbfc 0%,#ebedf0 100%);}
.t-mon{background:linear-gradient(165deg,#f2f4f6 0%,#e5e8ec 100%);}
.t-clean{background:linear-gradient(165deg,#e7e9ed 0%,#dcdfe4 100%);}
.tile .chip{background:linear-gradient(120deg,#1f5fd6,#5b7bff);color:#fff;border-color:transparent;}
.tile .chip .d{background:#fff;}
.tile .chip.kern{background:linear-gradient(120deg,#2b313c,#4c5563);color:#fff;}
.tile .chip.kern .d{background:#fff;}
.tags span{border-color:rgba(40,55,80,.18);background:rgba(255,255,255,.55);}
.t-ups .frame{border:0;box-shadow:0 14px 30px -22px rgba(30,42,64,.5);}
.t-ups .frame::after{content:"";position:absolute;inset:0;background:linear-gradient(150deg,transparent 40%,rgba(31,95,214,.26));z-index:2;pointer-events:none;}
.prod .frame{border:0;box-shadow:0 18px 40px -26px rgba(30,42,64,.5);}
.prod .frame::after{content:"";position:absolute;inset:0;background:linear-gradient(150deg,transparent 42%,rgba(31,95,214,.24));z-index:2;pointer-events:none;}
.prod .list{border:0;border-radius:16px;overflow:hidden;background:#dfe2e7;display:flex;flex-direction:column;gap:1px;box-shadow:0 30px 62px -40px rgba(30,42,64,.5);}
.prod .list a{border-top:0;background:linear-gradient(165deg,#fafbfc 0%,#ebedf0 100%);padding:18px 22px;transition:background .15s ease;}
.prod .list a:hover{background:linear-gradient(165deg,#ffffff 0%,#eef1f5 100%);}
.prod .list .ar{color:var(--accent);}
.cases{gap:1px;border-radius:16px;overflow:hidden;box-shadow:0 30px 62px -40px rgba(30,42,64,.5);}
.case{display:flex;flex-direction:column;background:linear-gradient(165deg,#fafbfc 0%,#ebedf0 100%);}
.case .frame{border:0;border-radius:0;height:208px;box-shadow:none;}
.case .frame::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(22,30,48,.3));z-index:2;pointer-events:none;}
.case .body{padding:22px 24px 26px;display:flex;flex-direction:column;gap:9px;flex:1;}
.case .meta{margin-top:0;}
.case h4{margin-top:0;font-size:19px;letter-spacing:-.02em;}
.case .go{margin-top:auto;padding-top:14px;font-size:13px;font-weight:500;color:var(--accent);display:flex;align-items:center;gap:7px;}
.tile, .case{transition:background .3s ease;}
.go .ar{display:inline-block;transition:transform .28s cubic-bezier(.2,.7,.2,1);}
.tile:hover{background:linear-gradient(165deg,#ffffff 0%,#eef2f7 100%);}
.t-mon:hover{background:linear-gradient(165deg,#ffffff 0%,#e9edf2 100%);}
.t-clean:hover{background:linear-gradient(165deg,#eef1f5 0%,#e3e7ed 100%);}
.case:hover{background:linear-gradient(165deg,#ffffff 0%,#eef2f7 100%);}
.tile:hover .go, .case:hover .go, .prod .list a:hover .ar{color:var(--accent-ink);}
.tile:hover .go .ar, .case:hover .go .ar, .prod .list a:hover .ar{transform:translateX(5px);}
.eod{border:0;background:linear-gradient(120deg,#2b313c,#3c4757);color:#fff;box-shadow:0 24px 50px -30px rgba(30,42,64,.6);}
.eod h3, .eod .phone{color:#fff;}
.eod .sub{color:rgba(255,255,255,.78);}
.eod .lbl{color:#9cc0ff;}
.eod .lbl .d{background:#9cc0ff;box-shadow:0 0 0 3px rgba(255,255,255,.14);}
.secnum .bar{background:#6b7686;}
.werken .secnum .bar{background:rgba(255,255,255,.4);}
.prodcards{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:#dfe2e7;border-radius:16px;overflow:hidden;box-shadow:0 30px 62px -40px rgba(30,42,64,.5);}
.pc{background:linear-gradient(165deg,#fafbfc,#eef1f5);display:grid;grid-template-columns:240px 1fr;min-height:216px;color:inherit;transition:background .25s ease;}
.pc:hover{background:linear-gradient(165deg,#ffffff,#eef2f7);}
.pc .frame{position:relative;overflow:hidden;background:#dcd8cf;}
.pc .frame::after{content:"";position:absolute;inset:0;background:linear-gradient(150deg,transparent 46%,rgba(31,95,214,.2));z-index:2;pointer-events:none;}
.pc .body{padding:28px 30px;display:flex;flex-direction:column;}
.pc h3{font-size:23px;letter-spacing:-.02em;}
.pc p{margin-top:10px;color:var(--ink-2);font-size:14.5px;line-height:1.55;max-width:34ch;}
.pc .spec{margin-top:14px;font-family:var(--mono);font-size:10px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-3);}
.pc .go{margin-top:auto;padding-top:18px;font-size:13px;font-weight:500;color:var(--accent);display:inline-flex;align-items:center;gap:7px;}
.pc .go .ar{display:inline-block;transition:transform .26s cubic-bezier(.2,.7,.2,1);}
.pc:hover .go .ar{transform:translateX(5px);}
.pfc{padding:var(--sec-y) 0;}
.pfc-panel{display:grid;grid-template-columns:.82fr 1.18fr;border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:0 40px 80px -50px rgba(30,42,64,.55);}
.pfc-l{padding:46px 42px;background:var(--bg-2);display:flex;flex-direction:column;}
.pfc-seclab{display:flex;align-items:center;gap:0;white-space:nowrap;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);}
.pfc-seclab .bar{width:26px;height:1px;background:var(--ink-3);margin-right:14px;}
.pfc-l h3{font-size:27px;letter-spacing:-.025em;line-height:1.1;margin-top:16px;max-width:18ch;}
.pfc-l .sub{font-size:14.5px;color:var(--ink-2);line-height:1.6;margin-top:14px;max-width:40ch;}
.pfc-aside{margin-top:auto;padding-top:34px;display:flex;flex-direction:column;}
.pfc-aside .a{display:flex;flex-direction:column;gap:3px;padding:14px 0;border-top:1px solid var(--line);}
.pfc-aside .a .k{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);}
.pfc-aside .a .v{font-size:16px;color:var(--ink);letter-spacing:-.01em;}
.pfc-form{background:#fff;padding:42px 44px;display:flex;flex-direction:column;}
.pfc-form .pfc-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.pfc-form .pfcf{display:flex;flex-direction:column;gap:8px;margin-top:16px;}
.pfc-form .pfcf .l{font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);}
.pfc-form .pfcf input, .pfc-form .pfcf select, .pfc-form .pfcf textarea{border:1px solid var(--line);border-radius:8px;background:var(--bg-2);padding:12px 14px;font-family:var(--sans);font-size:14px;color:var(--ink);transition:border-color .2s,box-shadow .2s,background .2s;}
.pfc-form .pfcf textarea{min-height:104px;resize:vertical;}
.pfc-form .pfcf input:focus, .pfc-form .pfcf select:focus, .pfc-form .pfcf textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(31,95,214,.12);background:#fff;}
.pfc-form .pfc-consent{font-size:12.5px;color:var(--ink-3);line-height:1.5;margin-top:18px;}
.pfc-form .pfc-submit{align-self:flex-start;margin-top:16px;cursor:pointer;border:0;}
.secnum{display:inline-flex;align-items:center;gap:11px;white-space:nowrap;}
.secnum .num{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:7px;background:var(--accent);color:#fff;font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:0;line-height:1;box-shadow:0 4px 12px -4px rgba(31,95,214,.55);flex:none;}
/* ===== light topbar variant (all non-front pages, from Contact artboard) ===== */
body.nav-light .topbar.over .head{background:linear-gradient(180deg,rgba(255,255,255,.6),rgba(255,255,255,.3));border-color:rgba(255,255,255,.8);box-shadow:inset 0 1px 0 rgba(255,255,255,.95),0 18px 44px -26px rgba(20,25,40,.45);}
body.nav-light .topbar.over nav.links{color:var(--ink-2);}
body.nav-light .topbar.over nav.links a{color:var(--ink-2);}
body.nav-light .topbar.over nav.links a:hover{background:rgba(0,0,0,.05);color:var(--ink);}
body.nav-light .topbar.over nav.links a.active{background:rgba(31,95,214,.1);color:var(--accent);}
body.nav-light .topbar.over .brand b{color:var(--ink);}
body.nav-light .topbar.over .brand .mono{color:var(--ink-3);}
body.nav-light .topbar.over .flag{color:var(--ink-2);}
body.nav-light .topbar.over .flag .lng{color:var(--ink-2);}
body.nav-light .topbar.over .flag .caret{color:var(--ink-3);}
body.nav-light .topbar.over .flag:hover{background:rgba(0,0,0,.05);}
body.nav-light .topbar.over .flag.flag-static:hover{background:none;}
body.nav-light .m-topbar.over .m-bar{background:linear-gradient(180deg,rgba(255,255,255,.62),rgba(255,255,255,.34));border-color:rgba(255,255,255,.8);box-shadow:inset 0 1px 0 rgba(255,255,255,.95),0 16px 36px -24px rgba(20,25,40,.45);}
body.nav-light .m-topbar.over .m-bar .brand b{color:var(--ink);}
body.nav-light .m-topbar.over .m-bar .menu span{background:var(--ink);}
/* ===== contact page sections ===== */
.ct-seclab{display:flex;align-items:center;gap:0;white-space:nowrap;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);}
.ct-seclab .bar{order:-1;width:26px;height:1px;background:var(--ink-3);margin-right:14px;}
.ct-seclab .n::after{content:"\00a0\00b7\00a0";}
.ct-sec{padding:var(--sec-y) 0;position:relative;isolation:isolate;}
.ct-sec::before{content:"";position:absolute;top:0;left:0;right:0;height:560px;z-index:-1;pointer-events:none;}
.ct-sechead{display:flex;flex-direction:column;gap:0;max-width:62ch;margin-bottom:40px;}
.ct-sechead h2{font-size:38px;letter-spacing:-.03em;line-height:1.05;}
.ct-sechead .intro{font-size:16px;color:var(--ink-2);line-height:1.6;margin-top:14px;}
.ct-routes{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;}
.ct-route{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:14px;background:linear-gradient(165deg,#fcfcfd 0%,#eef1f5 100%);padding:30px 32px;text-decoration:none;color:inherit;box-shadow:0 16px 34px -28px rgba(30,42,64,.5);transition:background .3s ease,border-color .3s ease;}
.ct-route:hover{background:linear-gradient(165deg,#ffffff 0%,#eef2f7 100%);}
.ct-route.accent{background:radial-gradient(680px 340px at 88% -40%,rgba(31,95,214,.1),transparent 62%),linear-gradient(165deg,#fcfcfd,#eef1f5);border-color:rgba(31,95,214,.35);}
.ct-route.accent:hover{background:radial-gradient(680px 340px at 88% -40%,rgba(31,95,214,.14),transparent 62%),linear-gradient(165deg,#ffffff,#eef2f7);}
.ct-route .tag{align-self:flex-start;white-space:nowrap;font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-2);border:1px solid var(--line-2);border-radius:999px;padding:5px 11px;}
.ct-route.accent .tag{color:#fff;background:linear-gradient(120deg,#1f5fd6,#5b7bff);border-color:transparent;}
.ct-route h4{font-size:23px;letter-spacing:-.02em;margin-top:18px;}
.ct-route p{font-size:14.5px;line-height:1.6;color:var(--ink-2);margin-top:10px;}
.ct-route .ch{margin-top:22px;padding-top:18px;border-top:1px solid var(--line);font-size:13.5px;font-weight:500;color:var(--accent);display:inline-flex;align-items:center;gap:7px;}
.ct-route .ch .ar{transition:transform .28s cubic-bezier(.2,.7,.2,1);}
.ct-route:hover .ch{color:var(--accent-ink);}
.ct-route:hover .ch .ar{transform:translateX(5px);}
.ct-form-panel{display:grid;grid-template-columns:.82fr 1.18fr;border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:0 40px 80px -50px rgba(30,42,64,.55);}
.ct-form-l{padding:46px 42px;background:var(--bg-2);display:flex;flex-direction:column;}
.ct-form-l h3{font-size:38px;letter-spacing:-.03em;line-height:1.05;margin-top:16px;max-width:18ch;}
.ct-form-l .sub{font-size:14.5px;color:var(--ink-2);line-height:1.6;margin-top:14px;max-width:40ch;}
.ct-aside{margin-top:auto;padding-top:34px;display:flex;flex-direction:column;}
.ct-aside .a{display:flex;flex-direction:column;gap:3px;padding:14px 0;border-top:1px solid var(--line);}
.ct-aside .a .k{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);}
.ct-aside .a .v{font-size:16px;color:var(--ink);letter-spacing:-.01em;}
.ct-form{background:#fff;padding:42px 44px;display:flex;flex-direction:column;}
.ct-form .ctf-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.ct-form .ctf{display:flex;flex-direction:column;gap:8px;margin-top:16px;}
.ct-form .ctf-row .ctf{margin-top:16px;}
.ct-form .ctf .l{font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);}
.ct-form .ctf input,.ct-form .ctf select,.ct-form .ctf textarea{border:1px solid var(--line);border-radius:8px;background:var(--bg-2);padding:12px 14px;font-family:var(--sans);font-size:14px;color:var(--ink);transition:border-color .2s ease,box-shadow .2s ease,background .2s ease;}
.ct-form .ctf textarea{min-height:104px;resize:vertical;}
.ct-form .ctf input:focus,.ct-form .ctf select:focus,.ct-form .ctf textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(31,95,214,.12);background:#fff;}
.ct-form .ctf-consent{display:flex;align-items:flex-start;gap:11px;font-size:12.5px;color:var(--ink-2);line-height:1.55;margin-top:18px;cursor:pointer;}
.ct-form .ctf-consent input{position:absolute;width:1px;height:1px;opacity:0;}
.ct-form .ctf-consent .cs-box{flex:none;width:18px;height:18px;margin-top:1px;border:1px solid var(--line-2);border-radius:5px;background:var(--bg-2);display:flex;align-items:center;justify-content:center;transition:background .15s ease,border-color .15s ease,box-shadow .15s ease;}
.ct-form .ctf-consent .cs-box svg{width:11px;height:11px;stroke:#fff;stroke-width:3;fill:none;opacity:0;transition:opacity .15s ease;}
.ct-form .ctf-consent input:checked + .cs-box{background:var(--accent);border-color:var(--accent);}
.ct-form .ctf-consent input:checked + .cs-box svg{opacity:1;}
.ct-form .ctf-consent input:focus-visible + .cs-box{box-shadow:0 0 0 3px rgba(31,95,214,.22);}
.ct-form .ctf-consent a{color:var(--accent);text-decoration:underline;text-underline-offset:2px;}
.ct-form .ctf-note{font-size:12.5px;color:var(--ink-3);line-height:1.5;margin-top:14px;}
.ct-form .ctf-submit{align-self:flex-start;margin-top:16px;cursor:pointer;border:0;}
.ct-visit2{display:grid;grid-template-columns:1.25fr .9fr;gap:28px;align-items:stretch;}
.ct-map2{position:relative;display:block;border-radius:18px;overflow:hidden;border:1px solid var(--line);min-height:460px;background:#dde1e6;box-shadow:0 30px 60px -42px rgba(30,42,64,.5);}
.ct-map2 .anno{top:14px;left:14px;}
.ct-map2 iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block;}
.ct-map2 .map-pin{position:absolute;z-index:3;left:50%;top:50%;transform:translate(-50%,-50%);display:inline-flex;align-items:center;gap:8px;background:var(--paper);border:1px solid var(--line);border-radius:999px;padding:8px 14px 8px 12px;font-size:13px;font-weight:500;color:var(--ink);box-shadow:0 14px 32px -14px rgba(20,25,40,.55);}
.ct-map2 .map-pin .dot{width:9px;height:9px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px rgba(31,95,214,.18);}
.ct-visit-card{border:1px solid var(--line);border-radius:18px;background:var(--paper);box-shadow:0 30px 60px -42px rgba(30,42,64,.5);padding:32px 32px;display:flex;flex-direction:column;}
.ct-visit-card .k{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);display:block;}
.ct-visit-card .vc-addr{padding-bottom:22px;border-bottom:1px solid var(--line);}
.ct-visit-card .vc-addr p{font-size:18px;line-height:1.6;color:var(--ink);margin-top:10px;letter-spacing:-.01em;}
.ct-visit-card .vc-route{margin-top:16px;font-size:13.5px;font-weight:500;color:var(--accent);display:inline-flex;align-items:center;gap:7px;}
.ct-visit-card .vc-route .ar{transition:transform .28s cubic-bezier(.2,.7,.2,1);}
.ct-visit-card .vc-route:hover .ar{transform:translateX(4px);}
.ct-visit-card .vc-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px 24px;padding:22px 0;}
.ct-visit-card .vc-item b{display:block;font-size:15px;font-weight:500;color:var(--ink);margin-top:6px;letter-spacing:-.01em;}
.ct-visit-card .vc-admin{margin-top:auto;padding-top:20px;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;gap:8px;}
.ct-visit-card .vc-admin span{font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;color:var(--ink-3);border:1px solid var(--line-2);border-radius:6px;padding:6px 10px;}
.seclab{display:flex;align-items:center;white-space:nowrap;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);}
.seclab,.ct-seclab{gap:11px;}
.seclab .n,.ct-seclab .n{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:7px;background:var(--accent);color:#fff;font-size:11px;font-weight:500;letter-spacing:0;line-height:1;box-shadow:0 4px 12px -4px rgba(31,95,214,.55);flex:none;margin-right:0;}
.seclab .bar,.ct-seclab .bar,.m-seclab .bar,.m-ct-seclab .bar{display:none;}
.seclab .n::after,.ct-seclab .n::after,.m-seclab .n::after,.m-ct-seclab .n::after{content:none;}
/* ====================================================================
   Production additions (not from the artboards 1:1)
   · img-slot: replaces the design tool's <image-slot> element
   · functional mobile menu: artboard .ab-m spec, adapted to one DOM
   · media queries: the 390px mobile artboard implemented as breakpoints
   ==================================================================== */

/* content width: artboards are a fixed 1440px canvas; constrain on larger screens */
.wrap{max-width:1440px;margin:0 auto;}

/* image slots → real images (extracted from the design sidecar) */
.img-slot{display:block;width:100%;height:100%;object-fit:cover;}
/* placeholder for slots without a matching asset yet: see MISSING-ASSETS.md */
.img-slot--todo{display:flex;align-items:center;justify-content:center;width:100%;height:100%;background:repeating-linear-gradient(45deg,#dcd8cf 0 12px,#d3cfc6 12px 24px);color:var(--ink-3);font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;}

/* mobile topbar: hidden on desktop, glass bar over content on mobile */
.m-topbar{display:none;}
.m-topbar.over{position:absolute;top:calc(14px + env(safe-area-inset-top));left:14px;right:14px;z-index:6;}
.m-topbar.over .m-bar{background:linear-gradient(180deg,rgba(255,255,255,.10),rgba(255,255,255,.02) 55%),rgba(16,21,30,.38);backdrop-filter:blur(22px) saturate(1.6);-webkit-backdrop-filter:blur(22px) saturate(1.6);border:1px solid rgba(255,255,255,.22);border-radius:13px;box-shadow:inset 0 1px 0 rgba(255,255,255,.16),0 14px 34px -22px rgba(6,10,18,.75);}
.m-topbar.over .m-bar .brand b{color:#fff;}
.m-topbar.over .m-bar .menu span{background:#fff;}
.m-topbar .m-bar{border-bottom:0;border-radius:13px;}

/* functional mobile menu overlay (artboard: .ab-m.menu-open) */
.m-menu{position:fixed;inset:0;height:100dvh;z-index:50;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;}
body.menu-open .m-menu{display:flex;animation:mMenuIn .3s ease;}
body.menu-open{overflow:hidden;}
body.menu-open .m-bar .menu span:nth-child(1){transform:translateY(5.5px) rotate(45deg);}
body.menu-open .m-bar .menu span:nth-child(2){opacity:0;}
body.menu-open .m-bar .menu span:nth-child(3){transform:translateY(-5.5px) rotate(-45deg);}
/* animate only the TOP items (accordion headers .ln + direct links), not the nested sub-links */
body.menu-open .m-menu nav > .ln,
body.menu-open .m-menu nav > a{animation:mLinkIn .42s ease both;animation-delay:calc(.06s + var(--mi,0) * .05s);}

/* ============================ ≤768px ============================ */
@media (max-width:768px){
  .topbar{display:none;}
  .m-topbar{display:block;}
  .wrap{padding:0 20px;}

  /* hero (m-hero spec) */
  /* full-viewport hero: content stays top, CTA is pushed to the bottom edge
     (safe-area aware). min-height (not height) so nothing clips on short/landscape. */
  .hero{height:auto;min-height:100vh;min-height:calc(100lvh + 10vh);padding:0;} /* over-fill so it always covers the viewport. NB: web content cannot be pushed into the iOS top safe area in Safari (the negative-margin trick collapses through the body and even an overflow bleed does not paint there) — only the html canvas bg fills that band, so the top band on dark pages is the matching #11151c, not the live video. */
  .hero .inner{position:relative;inset:auto;min-height:100vh;min-height:var(--fc-vh, 100svh);display:flex;flex-direction:column;justify-content:flex-start;padding:calc(92px + env(safe-area-inset-top)) 0 calc(24px + env(safe-area-inset-bottom));}
  .hero .inner .wrap{display:flex;flex-direction:column;flex:1 1 auto;min-height:0;}
  .hero .left{display:flex;flex-direction:column;flex:1 1 auto;min-height:0;}
  .hero h1{font-size:36px;font-weight:700;margin-top:14px;}
  .hero h1 .rotate.rot-block{display:block;}
  .hero .lead{font-size:14px;margin-top:14px;}
  .hero-status{font-size:9.5px;padding:6px 11px;gap:9px;align-self:flex-start;}
  .hero-status .live{width:6px;height:6px;}
  .hero .cta{flex-direction:column;gap:10px;margin-top:auto;}
  .hero .cta .btn{justify-content:center;width:100%;}
  .hero .meta{border-left:0;padding-left:0;margin-top:30px;padding-top:24px;border-top:1px solid rgba(255,255,255,.16);display:grid;grid-template-columns:1fr 1fr;gap:18px 16px;}
  /* light "Vertrouwd door" bar (now below the hero) · mobile sizing */
  .trust .wrap{height:64px;}
  .trust .lbl{padding-right:18px;}
  .trust .track span{font-size:14px;padding:0 30px;}

  /* sections */
  .block,.ct-sec{padding:var(--sec-y) 0;}
  .sechead{flex-direction:column;align-items:flex-start;gap:14px;margin-bottom:24px;}
  .sechead h2,.ct-sechead h2{font-size:26px;}
  .sechead .intro,.ct-sechead .intro{font-size:13.5px;}

  /* services grid → stacked cards (m-list spec) */
  .svc{display:flex;flex-direction:column;border-radius:14px;}
  .tile,.t-ups,.t-mon,.t-mnt,.t-load,.t-clean{grid-column:auto;grid-row:auto;min-height:0;display:block;padding:20px;}
  .tile h3{font-size:20px !important;}
  .tile p{font-size:13px !important;}
  .t-ups .frame{min-height:160px;margin-top:14px;}
  .tile .chip{position:static;display:inline-flex;margin-top:0;}
  .tile .go{margin-top:12px;display:inline-flex;}

  /* product cards → single column (m-pcard spec) */
  .prodcards{grid-template-columns:1fr;border-radius:14px;}
  .pc{grid-template-columns:1fr;min-height:0;display:block;}
  .pc .frame{height:150px;}
  .pc .body{padding:15px 16px 17px;}
  .pc h3{font-size:18px;}
  .pc p{font-size:13px;}

  /* principles → single column (m-prin spec) */
  .prin{grid-template-columns:1fr;border-radius:14px;}
  .prin .p .ix{font-size:24px;}
  .prin .p h4{font-size:17px;}
  .prin .p p{font-size:13px;}

  /* cases → single column */
  .cases{grid-template-columns:1fr;border-radius:14px;}

  /* werken bij (m-werken spec) */
  .werken{padding:30px 20px;border-radius:14px;}
  .werken .wk-top{flex-direction:column;align-items:flex-start;gap:18px;margin-bottom:10px;}
  .werken h2{font-size:24px;margin-top:14px;}
  .werken .sub{font-size:13px;margin-top:14px;}
  .werken .wk-top .r{align-items:flex-start;width:100%;}
  .werken .wk-top .r .btn{width:100%;justify-content:center;}
  .werken .er{display:block;padding:18px 0;}
  .werken .er .big{font-size:44px;}
  .werken .er h5{font-size:18px;margin-top:12px;}
  .werken .er .proof{margin-top:8px;font-size:10px;}
  .werken .er .desc{margin-top:10px;font-size:13px;}

  /* pre-footer contact band (m-pfc spec) */
  .pfc{padding:var(--sec-y) 0;}
  .pfc-panel{grid-template-columns:1fr;}
  .pfc-l{padding:24px 20px;}
  .pfc-form{padding:24px 20px;}
  .pfc-form .pfc-row{grid-template-columns:1fr;gap:0;}
  .pfc-l h3{font-size:22px;}
  .pfc-form .pfc-submit{width:100%;justify-content:center;align-self:auto;}

  /* contact page */
  .ct-sec[style*="padding-top"]{padding-top:110px !important;}
  .ct-visit2{grid-template-columns:1fr;gap:18px;}
  .ct-map2{min-height:300px;}
  .ct-visit-card{padding:22px 20px;}
  .ct-visit-card .vc-addr p{font-size:15px;}
  .ct-routes{grid-template-columns:1fr;gap:13px;}
  .ct-route{padding:20px;}
  .ct-route h4{font-size:19px;}
  .ct-route p{font-size:13px;}
  .ct-form-panel{grid-template-columns:1fr;}
  .ct-form-l{padding:24px 20px;}
  .ct-form{padding:24px 20px;}
  .ct-form .ctf-row{grid-template-columns:1fr;gap:0;}
  .ct-form-l h3{font-size:22px;}
  .ct-form .ctf-submit{width:100%;justify-content:center;align-self:auto;}

  /* footer (m-foot spec) */
  footer{padding:34px 0 26px;margin-top:var(--sec-y);}
  .foot{grid-template-columns:1fr 1fr;gap:20px;}
  .foot > div:first-child{grid-column:1 / -1;}
  .foot-base{flex-direction:column;align-items:flex-start;gap:6px;margin-top:22px;padding-top:16px;}
}

/* ============================ ≤480px ============================ */
@media (max-width:480px){
  .hero h1{font-size:31px;line-height:1.04;letter-spacing:-.035em;font-weight:700;}
  .hero .lead{font-size:14px;}
  .sechead h2,.ct-sechead h2{font-size:24px;}
  /* cases → compact rows (m-case spec) */
  .cases{box-shadow:0 18px 40px -30px rgba(30,42,64,.5);}
  .case{display:grid;grid-template-columns:92px 1fr;gap:13px;align-items:center;padding:11px;}
  .case .frame{border-radius:8px;height:64px;}
  .case .body{padding:0;gap:4px;min-width:0;}
  .case .meta{font-size:9px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  .case h4{font-size:14px;line-height:1.25;}
  .case .go{display:none;}
  .vc-grid{gap:16px;}
}

/* ===== service-detail template (shared by 6 pages) · scoped by template body class ===== */
.page-template-service-detail .sp-hero{position:relative;padding:148px 40px var(--sec-y);}
.page-template-service-detail .sp-hero .eyebrow{display:flex;align-items:center;gap:12px;}
.page-template-service-detail .sp-hero .eyebrow .bar{width:26px;height:1px;background:#6b7686;}
.page-template-service-detail .sp-hero h1{font-size:64px;line-height:1.02;letter-spacing:-.045em;margin-top:22px;max-width:17ch;}
.page-template-service-detail .sp-hero .lead{margin-top:24px;font-size:19px;line-height:1.55;color:var(--ink-2);max-width:58ch;}
.page-template-service-detail .sp-hero .jump{display:flex;gap:12px;margin-top:36px;}
.page-template-service-detail .sp-hero .jump a{display:inline-flex;align-items:center;gap:10px;border:1px solid var(--line-2);background:var(--paper);border-radius:999px;padding:11px 18px;font-size:14px;font-weight:500;color:var(--ink);transition:border-color .2s,color .2s,box-shadow .2s;}
.page-template-service-detail .sp-hero .jump a:hover{border-color:var(--accent);color:var(--accent);box-shadow:0 0 0 4px rgba(31,95,214,.1);}
.page-template-service-detail .sp-hero .jump a .n{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--ink-3);}
.page-template-service-detail .sp-hero .jump a:hover .n{color:var(--accent);}
.page-template-service-detail .sp-sec{padding:var(--sec-y) 40px;}
.page-template-service-detail .sp-sec .sechead{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;margin-bottom:42px;}
.page-template-service-detail .sp-sec .lhs{display:flex;flex-direction:column;gap:0;max-width:60ch;}
.page-template-service-detail .sp-sec h2{font-size:38px;letter-spacing:-.03em;}
.page-template-service-detail .sp-sec .intro{color:var(--ink-2);font-size:16px;line-height:1.6;}
.page-template-service-detail .sp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.page-template-service-detail .sp-grid.cols4{grid-template-columns:repeat(4,1fr);}
.page-template-service-detail .sp-card{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--paper);text-decoration:none;color:inherit;box-shadow:0 14px 30px -26px rgba(30,42,64,.5);transition:box-shadow .3s ease,transform .3s ease;}
.page-template-service-detail .sp-card:hover{box-shadow:0 28px 54px -34px rgba(30,42,64,.55);transform:translateY(-3px);}
.page-template-service-detail .sp-card .frame{position:relative;height:204px;overflow:hidden;border-bottom:1px solid var(--line);background:#dcd8cf;}
.page-template-service-detail .sp-grid.cols4 .sp-card .frame{height:158px;}
.page-template-service-detail .sp-card .frame::after{content:"";position:absolute;inset:0;background:linear-gradient(150deg,transparent 46%,rgba(31,95,214,.2));z-index:2;pointer-events:none;}
.page-template-service-detail .sp-card .body{padding:24px 24px 26px;display:flex;flex-direction:column;flex:1;}
.page-template-service-detail .sp-card .hd{display:flex;align-items:center;gap:10px;min-height:20px;}
.page-template-service-detail .sp-card .ix{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;color:var(--ink-3);}
.page-template-service-detail .sp-card .chip{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:linear-gradient(120deg,#1f5fd6,#5b7bff);border-radius:999px;padding:4px 9px;}
.page-template-service-detail .sp-card .chip .d{width:6px;height:6px;border-radius:50%;background:#fff;}
.page-template-service-detail .sp-card .chip.kern{background:linear-gradient(120deg,#2b313c,#4c5563);}
.page-template-service-detail .sp-card .chip.soft{background:none;color:var(--ink-3);border:1px solid var(--line-2);}
.page-template-service-detail .sp-card .chip.soft .d{background:var(--ink-3);}
.page-template-service-detail .sp-card h3{font-size:23px;letter-spacing:-.02em;margin-top:13px;}
.page-template-service-detail .sp-grid.cols4 .sp-card h3{font-size:19px;}
.page-template-service-detail .sp-card p{margin-top:10px;color:var(--ink-2);line-height:1.55;font-size:14.5px;}
.page-template-service-detail .sp-grid.cols4 .sp-card p{font-size:13.5px;}
.page-template-service-detail .sp-card .go{margin-top:auto;padding-top:20px;font-size:13px;font-weight:500;color:var(--accent);display:inline-flex;align-items:center;gap:7px;}
.page-template-service-detail .sp-card .go .ar{transition:transform .28s cubic-bezier(.2,.7,.2,1);}
.page-template-service-detail .sp-card:hover .go .ar{transform:translateX(4px);}
.page-template-service-detail .sp-cta{background:linear-gradient(160deg,#23272f 0%,#1a1d24 100%);color:#fff;padding:var(--sec-y) 40px;}
.page-template-service-detail .sp-cta .in{display:flex;align-items:center;justify-content:space-between;gap:48px;}
.page-template-service-detail .sp-cta .secnum .bar{background:rgba(255,255,255,.4);}
.page-template-service-detail .sp-cta .secnum .mono{color:rgba(255,255,255,.55);}
.page-template-service-detail .sp-cta h2{font-size:36px;letter-spacing:-.03em;color:#fff;max-width:20ch;margin-top:16px;}
.page-template-service-detail .sp-cta p{margin-top:14px;color:#9aa3b2;font-size:15px;line-height:1.55;max-width:50ch;}
.page-template-service-detail .sp-cta .acts{display:flex;gap:12px;flex-shrink:0;}
.page-template-service-detail .sp-cta .btn-ghost{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.28);}
.page-template-service-detail .sp-cta .btn-ghost:hover{color:#cfe0ff;border-color:#7fb0ff;box-shadow:0 0 0 4px rgba(127,176,255,.2);}
.page-template-service-detail .prod .list .rowtext{display:flex;flex-direction:column;gap:5px;min-width:0;}
.page-template-service-detail .prod .list .rowtext .spec{font-family:var(--mono);font-size:10px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-3);}
.page-template-service-detail .svc .tile .tags{margin-top:14px;}
.page-template-service-detail .svc-hero{position:relative;padding:140px 0 var(--sec-y);}
.page-template-service-detail .svc-hero .row{display:grid;grid-template-columns:1fr 360px;gap:64px;align-items:flex-end;}
.page-template-service-detail .svc-hero .badges{display:flex;align-items:center;gap:12px;margin-bottom:24px;}
.page-template-service-detail .svc-hero .ix{font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--ink-3);}
.page-template-service-detail .svc-hero .chip{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:linear-gradient(120deg,#2b313c,#4c5563);border-radius:999px;padding:5px 11px;}
.page-template-service-detail .svc-hero .chip .d{width:6px;height:6px;border-radius:50%;background:#fff;}
.page-template-service-detail .svc-hero .ey{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);}
.page-template-service-detail .svc-hero h1{font-size:66px;line-height:1.0;letter-spacing:-.045em;max-width:16ch;}
.page-template-service-detail .svc-hero .lead{margin-top:26px;font-size:18px;line-height:1.55;color:var(--ink-2);max-width:62ch;}
.page-template-service-detail .svc-hero .acts{display:flex;flex-wrap:wrap;gap:12px;margin-top:34px;}
.page-template-service-detail .svc-hero .meta{border-left:1px solid var(--line-2);padding-left:26px;display:flex;flex-direction:column;gap:22px;}
.page-template-service-detail .svc-hero .meta .k{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);}
.page-template-service-detail .svc-hero .meta .v{font-size:14px;margin-top:5px;color:var(--ink);line-height:1.45;}
.page-template-service-detail .svc-heroimg{position:relative;height:468px;width:calc(100% - 80px);max-width:1360px;margin:40px auto 0;background:#dcd8cf;border:1px solid var(--line);overflow:hidden;}
.page-template-service-detail .svc-heroimg::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(31,95,214,.16),transparent 50%);z-index:2;pointer-events:none;}
.page-template-service-detail .svc-sec{padding:var(--sec-y) 0;position:relative;isolation:isolate;}
.page-template-service-detail .svc-sec::before, .page-template-service-detail .blocks::before{content:"";position:absolute;top:0;left:0;right:0;height:560px;z-index:-1;pointer-events:none;}
.page-template-service-detail .blocks{position:relative;isolation:isolate;}
.page-template-service-detail .svc-sec.tight{padding:var(--sec-y) 0;}
.page-template-service-detail .seclab .n::after{content:"\00a0\00b7\00a0";}
.page-template-service-detail .seclab .bar{order:-1;width:26px;height:1px;background:var(--ink-3);margin-right:14px;}
.page-template-service-detail .ov{display:grid;grid-template-columns:1fr 1fr;gap:64px;margin-top:24px;align-items:flex-start;}
.page-template-service-detail .ov h2{font-size:38px;letter-spacing:-.03em;max-width:18ch;line-height:1.05;}
.page-template-service-detail .ov .body{display:flex;flex-direction:column;gap:18px;padding-top:6px;}
.page-template-service-detail .ov .body p{font-size:16px;color:var(--ink-2);line-height:1.65;}
.page-template-service-detail .caps{display:flex;flex-wrap:wrap;gap:8px;margin-top:36px;}
.page-template-service-detail .caps span{font-family:var(--mono);font-size:11px;letter-spacing:.02em;color:var(--ink);border:1px solid var(--line-2);background:var(--paper);border-radius:6px;padding:7px 12px;}
.page-template-service-detail .blocks{padding:var(--sec-y) 40px;}
.page-template-service-detail .cb{display:grid;gap:56px;align-items:stretch;max-width:1360px;margin-left:auto;margin-right:auto;}
.page-template-service-detail .cb + .cb{margin-top:64px;}
.page-template-service-detail .cb.normal{grid-template-columns:1.05fr 1fr;}
.page-template-service-detail .cb.flip{grid-template-columns:1fr 1.05fr;}
.page-template-service-detail .cb .txt{align-self:center;}
.page-template-service-detail .cb .dlab{display:inline-flex;align-items:center;gap:9px;white-space:nowrap;font-family:var(--mono);font-size:13px;font-weight:600;letter-spacing:.02em;margin-bottom:var(--eyb-gap);}
.page-template-service-detail .cb .dlab .s{color:var(--accent);}
.page-template-service-detail .cb .dlab .l{color:var(--ink);text-transform:lowercase;letter-spacing:.04em;}
.page-template-service-detail .cb .dlab + h3,.single-fc_case .cb .dlab + h3,.single-fc_case .m-cb .dlab + h3{margin-top:0;}
.page-template-service-detail .cb h3{font-size:30px;font-weight:500;letter-spacing:-.02em;line-height:1.1;margin:20px 0 14px;max-width:18ch;}
.page-template-service-detail .cb p{font-size:15px;color:var(--ink-2);line-height:1.65;max-width:48ch;}
.page-template-service-detail .cb .pts{margin-top:24px;border-top:1px solid var(--line);}
.page-template-service-detail .cb .pts .pt{display:grid;grid-template-columns:24px 1fr;gap:12px;padding:13px 0;border-bottom:1px solid var(--line);align-items:baseline;}
.page-template-service-detail .cb .pts .pt .pn{font-family:var(--mono);font-size:11px;color:var(--accent);}
.page-template-service-detail .cb .pts .pt .pv{font-size:14.5px;color:var(--ink);}
.page-template-service-detail .cb .img{position:relative;min-height:392px;background:#dcd8cf;overflow:hidden;border:1px solid var(--line);}
.page-template-service-detail .cb .img::after{content:"";position:absolute;inset:0;background:linear-gradient(140deg,transparent 52%,rgba(31,95,214,.16));z-index:2;pointer-events:none;}
.page-template-service-detail .scope{padding:var(--sec-y) 40px;}
.page-template-service-detail .scope .grid{display:grid;grid-template-columns:1fr 1.45fr;gap:64px;align-items:flex-start;}
.page-template-service-detail .scope h2{font-size:34px;letter-spacing:-.03em;margin:18px 0 14px;max-width:14ch;line-height:1.08;}
.page-template-service-detail .scope .intro{color:var(--ink-2);font-size:15px;line-height:1.6;max-width:40ch;}
.page-template-service-detail .scope .acc{border:1px solid var(--line);background:var(--paper);}
.page-template-service-detail .scope details{border-top:1px solid var(--line);}
.page-template-service-detail .scope details:first-child{border-top:0;}
.page-template-service-detail .scope summary{list-style:none;cursor:pointer;display:grid;grid-template-columns:200px 1fr 24px;gap:20px;align-items:center;padding:18px 22px;transition:background .2s ease;}
.page-template-service-detail .scope summary::-webkit-details-marker{display:none;}
.page-template-service-detail .scope summary:hover{background:var(--bg);}
.page-template-service-detail .scope details[open] summary{background:var(--bg);}
.page-template-service-detail .scope summary .k{font-family:var(--mono);font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink);}
.page-template-service-detail .scope summary .v{font-size:14px;color:var(--ink-2);}
.page-template-service-detail .scope summary .pm{justify-self:end;width:22px;height:22px;border-radius:3px;border:1px solid var(--line-2);background:var(--paper);color:var(--ink);display:inline-flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:15px;line-height:1;}
.page-template-service-detail .scope details[open] summary .pm{background:var(--ink);border-color:var(--ink);color:#fff;}
.page-template-service-detail .scope details[open] summary .pm .plus{display:none;}
.page-template-service-detail .scope summary .pm .min{display:none;}
.page-template-service-detail .scope details[open] summary .pm .min{display:inline;}
.page-template-service-detail .scope .more{padding:0 24px 18px 222px;background:var(--bg);}
.page-template-service-detail .scope .more p{margin:0;font-size:14px;color:var(--ink-2);line-height:1.65;max-width:62ch;}
.page-template-service-detail .svc-ov{padding:var(--sec-y) 0;position:relative;isolation:isolate;}
.page-template-service-detail .svc-ov::before{content:"";position:absolute;top:0;left:0;right:0;height:560px;z-index:-1;pointer-events:none;}
@media (min-width:769px){.page-template-service-detail .svc-ov::before{display:none;}}
.page-template-service-detail .svc-wp .ov-h{font-size:46px;letter-spacing:-.04em;line-height:1.04;max-width:24ch;}
.page-template-service-detail .svc-wp .ov-h em{font-style:normal;color:var(--accent);}
.page-template-service-detail .svc-ov .ov-intro{display:grid;grid-template-columns:1.25fr .75fr;gap:64px;margin-top:40px;align-items:start;}
.page-template-service-detail .svc-ov .lead{display:flex;flex-direction:column;gap:18px;max-width:60ch;}
.page-template-service-detail .svc-ov .lead p{font-size:17px;line-height:1.72;color:var(--ink-2);}
.page-template-service-detail .svc-ov .lead p b{color:var(--ink);font-weight:500;}
.page-template-service-detail .svc-ov .ov-stats{border-top:1px solid var(--ink);}
.page-template-service-detail .svc-ov .ov-stats .s{display:flex;align-items:baseline;justify-content:space-between;gap:20px;padding:15px 0;border-bottom:1px solid var(--line);}
.page-template-service-detail .svc-ov .ov-stats .k{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);}
.page-template-service-detail .svc-ov .ov-stats .v{font-size:14px;color:var(--ink);text-align:right;letter-spacing:-.01em;}
.page-template-service-detail .svc-ov .wp-head{display:flex;align-items:baseline;justify-content:space-between;margin-top:58px;padding-bottom:13px;border-bottom:1px solid var(--ink);}
.page-template-service-detail .svc-ov .wp-head .t{font-size:16px;font-weight:600;letter-spacing:-.01em;}
.page-template-service-detail .svc-ov .wp-head .c{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--ink-3);}
.page-template-service-detail .md input{position:absolute;opacity:0;pointer-events:none;}
.page-template-service-detail .md .cols{display:grid;grid-template-columns:0.9fr 1.1fr;margin-top:22px;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--paper);box-shadow:0 24px 54px -42px rgba(30,42,64,.5);}
.page-template-service-detail .md .list{border-right:1px solid var(--line);}
.page-template-service-detail .md .list label{display:grid;grid-template-columns:34px 1fr 18px;gap:14px;align-items:center;padding:18px 22px;cursor:pointer;border-bottom:1px solid var(--line);transition:background .18s;}
.page-template-service-detail .md .list label:last-of-type{border-bottom:0;}
.page-template-service-detail .md .list label .n{font-family:var(--mono);font-size:11px;color:var(--ink-3);}
.page-template-service-detail .md .list label .t{font-size:17px;letter-spacing:-.01em;color:var(--ink-2);}
.page-template-service-detail .md .list label .ar{justify-self:end;color:var(--ink-3);opacity:0;transition:opacity .18s;font-family:var(--mono);}
.page-template-service-detail .md .list label:hover{background:var(--bg-2);}
.page-template-service-detail .md .detail{padding:34px 34px;background:linear-gradient(180deg,#fbfcfd,#fff);}
.page-template-service-detail .md .pane{display:none;}
.page-template-service-detail .md .pane .pn{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--accent);}
.page-template-service-detail .md .pane h4{font-size:28px;letter-spacing:-.02em;margin-top:12px;}
.page-template-service-detail .md .pane p{font-size:15px;line-height:1.7;color:var(--ink-2);margin-top:14px;max-width:52ch;}
.page-template-service-detail .md #u1:checked~.cols .list label[for="u1"], .page-template-service-detail .md #u2:checked~.cols .list label[for="u2"], .page-template-service-detail .md #u3:checked~.cols .list label[for="u3"], .page-template-service-detail .md #u4:checked~.cols .list label[for="u4"], .page-template-service-detail .md #u5:checked~.cols .list label[for="u5"], .page-template-service-detail .md #u6:checked~.cols .list label[for="u6"], .page-template-service-detail .md #u7:checked~.cols .list label[for="u7"]{background:var(--ink);}
.page-template-service-detail .md #u1:checked~.cols .list label[for="u1"] .t, .page-template-service-detail .md #u1:checked~.cols .list label[for="u1"] .n, .page-template-service-detail .md #u1:checked~.cols .list label[for="u1"] .ar, .page-template-service-detail .md #u2:checked~.cols .list label[for="u2"] .t, .page-template-service-detail .md #u2:checked~.cols .list label[for="u2"] .n, .page-template-service-detail .md #u2:checked~.cols .list label[for="u2"] .ar, .page-template-service-detail .md #u3:checked~.cols .list label[for="u3"] .t, .page-template-service-detail .md #u3:checked~.cols .list label[for="u3"] .n, .page-template-service-detail .md #u3:checked~.cols .list label[for="u3"] .ar, .page-template-service-detail .md #u4:checked~.cols .list label[for="u4"] .t, .page-template-service-detail .md #u4:checked~.cols .list label[for="u4"] .n, .page-template-service-detail .md #u4:checked~.cols .list label[for="u4"] .ar, .page-template-service-detail .md #u5:checked~.cols .list label[for="u5"] .t, .page-template-service-detail .md #u5:checked~.cols .list label[for="u5"] .n, .page-template-service-detail .md #u5:checked~.cols .list label[for="u5"] .ar, .page-template-service-detail .md #u6:checked~.cols .list label[for="u6"] .t, .page-template-service-detail .md #u6:checked~.cols .list label[for="u6"] .n, .page-template-service-detail .md #u6:checked~.cols .list label[for="u6"] .ar, .page-template-service-detail .md #u7:checked~.cols .list label[for="u7"] .t, .page-template-service-detail .md #u7:checked~.cols .list label[for="u7"] .n, .page-template-service-detail .md #u7:checked~.cols .list label[for="u7"] .ar{color:#fff;opacity:1;}
.page-template-service-detail .md #u1:checked~.cols .detail .pane[data-i="1"], .page-template-service-detail .md #u2:checked~.cols .detail .pane[data-i="2"], .page-template-service-detail .md #u3:checked~.cols .detail .pane[data-i="3"], .page-template-service-detail .md #u4:checked~.cols .detail .pane[data-i="4"], .page-template-service-detail .md #u5:checked~.cols .detail .pane[data-i="5"], .page-template-service-detail .md #u6:checked~.cols .detail .pane[data-i="6"], .page-template-service-detail .md #u7:checked~.cols .detail .pane[data-i="7"]{display:block;}
.page-template-service-detail .appr-head{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;margin-bottom:40px;}
.page-template-service-detail .appr-head .lhs{display:flex;flex-direction:column;gap:0;max-width:60ch;}
.page-template-service-detail .appr-head h2{font-size:38px;letter-spacing:-.03em;max-width:18ch;line-height:1.05;margin-top:2px;}
.page-template-service-detail .appr-head .intro{font-size:15px;color:var(--ink-2);line-height:1.6;max-width:52ch;}
.page-template-service-detail .appr{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1px;border-radius:16px;overflow:hidden;box-shadow:0 30px 62px -40px rgba(30,42,64,.5);background:#dfe2e7;margin-top:0;}
.page-template-service-detail .appr .c{padding:26px 22px 24px;background:linear-gradient(165deg,#fafbfc 0%,#ebedf0 100%);display:flex;flex-direction:column;gap:0;min-height:auto;border-left:0;transition:background .3s ease;}
.page-template-service-detail .appr .c:hover{background:linear-gradient(165deg,#ffffff 0%,#eef2f7 100%);}
.page-template-service-detail .appr .c .n{font-family:var(--mono);font-size:30px;font-weight:500;letter-spacing:-.03em;color:var(--line-2);line-height:1;}
.page-template-service-detail .appr .c h4{margin-top:16px;font-size:18px;font-weight:500;letter-spacing:-.015em;line-height:1.2;}
.page-template-service-detail .appr .c p{margin-top:8px;font-size:13.5px;color:var(--ink-2);line-height:1.6;}
.page-template-service-detail .cases-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:30px;}
.page-template-service-detail .ccard{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--paper);box-shadow:0 14px 30px -26px rgba(30,42,64,.5);transition:box-shadow .3s,transform .3s;}
.page-template-service-detail .ccard:hover{box-shadow:0 28px 54px -34px rgba(30,42,64,.55);transform:translateY(-3px);}
.page-template-service-detail .ccard .frame{position:relative;height:236px;background:#dcd8cf;overflow:hidden;border-bottom:1px solid var(--line);}
.page-template-service-detail .ccard .frame::after{content:"";position:absolute;inset:0;background:linear-gradient(150deg,transparent 46%,rgba(31,95,214,.2));z-index:2;pointer-events:none;}
.page-template-service-detail .ccard .body{padding:22px 24px 24px;}
.page-template-service-detail .ccard .meta{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);}
.page-template-service-detail .ccard h4{font-size:20px;letter-spacing:-.02em;margin-top:10px;}
.page-template-service-detail .svc-cta{padding:var(--sec-y) 0;}
.page-template-service-detail .svc-cta .in{display:flex;align-items:center;justify-content:space-between;gap:48px;flex-wrap:wrap;background:radial-gradient(880px 430px at 84% -30%,rgba(31,95,214,.16),transparent 64%),var(--paper);border:1px solid var(--line);border-radius:22px;padding:48px 52px;box-shadow:0 34px 70px -46px rgba(30,42,64,.55);}
.page-template-service-detail .svc-cta .chip{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-ink);border:1px solid rgba(31,95,214,.3);background:rgba(31,95,214,.06);border-radius:999px;padding:5px 11px;}
.page-template-service-detail .svc-cta .chip .pulse{width:7px;height:7px;border-radius:50%;background:#22c07a;box-shadow:0 0 0 0 rgba(34,192,122,.6);animation:cpulse 2s infinite;}
.page-template-service-detail .svc-cta h2{font-size:44px;font-weight:500;letter-spacing:-.025em;line-height:1.05;margin:16px 0 12px;color:var(--ink);max-width:18ch;}
.page-template-service-detail .svc-cta p{color:var(--ink-2);font-size:16px;line-height:1.55;max-width:46ch;}
.page-template-service-detail .svc-cta .side{display:flex;flex-direction:column;gap:14px;min-width:230px;}
.page-template-service-detail .svc-cta .phone{font-family:var(--mono);font-size:24px;font-weight:500;color:var(--ink);}
.page-template-service-detail .other{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;border:0;border-radius:16px;overflow:hidden;background:#dfe2e7;box-shadow:0 30px 62px -40px rgba(30,42,64,.5);margin-top:28px;}
.page-template-service-detail .other a{position:relative;padding:28px 24px 24px;min-height:204px;background:linear-gradient(165deg,#fafbfc 0%,#ebedf0 100%);display:flex;flex-direction:column;color:inherit;transition:background .3s ease;}
.page-template-service-detail .other a:hover{background:linear-gradient(165deg,#ffffff 0%,#eef2f7 100%);}
.page-template-service-detail .other a .ix{font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--ink-3);}
.page-template-service-detail .other a h4{margin-top:14px;font-size:21px;font-weight:500;letter-spacing:-.02em;}
.page-template-service-detail .other a p{margin-top:10px;font-size:14px;color:var(--ink-2);line-height:1.55;}
.page-template-service-detail .other a .go{margin-top:auto;padding-top:18px;font-size:13px;font-weight:500;color:var(--accent);display:flex;align-items:center;gap:7px;}
.page-template-service-detail .other a .go .ar{display:inline-block;transition:transform .28s cubic-bezier(.2,.7,.2,1);}
.page-template-service-detail .other a:hover .go .ar{transform:translateX(5px);}
.page-template-service-detail .other a .chip{position:absolute;top:26px;right:24px;display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:linear-gradient(120deg,#1f5fd6,#5b7bff);border-radius:999px;padding:4px 9px;}
.page-template-service-detail .other a .chip .d{width:6px;height:6px;border-radius:50%;background:#fff;}
.page-template-service-detail .other a .chip.kern{background:linear-gradient(120deg,#2b313c,#4c5563);}
.page-template-service-detail .prodstrip{margin-top:28px;display:grid;grid-template-columns:1.05fr 1fr;gap:48px;align-items:center;border:1px solid var(--line);border-radius:16px;background:linear-gradient(165deg,#fafbfc 0%,#ebedf0 100%);padding:36px 40px;box-shadow:0 30px 62px -40px rgba(30,42,64,.5);text-decoration:none;color:inherit;transition:background .3s ease,transform .3s ease,box-shadow .3s ease;}
.page-template-service-detail .prodstrip:hover{background:linear-gradient(165deg,#ffffff 0%,#eef2f7 100%);transform:translateY(-2px);box-shadow:0 40px 74px -44px rgba(30,42,64,.55);}
.page-template-service-detail .prodstrip .chip.kern{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:linear-gradient(120deg,#2b313c,#4c5563);border-radius:999px;padding:4px 9px;}
.page-template-service-detail .prodstrip .chip.kern .d{width:6px;height:6px;border-radius:50%;background:#fff;}
.page-template-service-detail .prodstrip h4{margin-top:14px;font-size:27px;font-weight:500;letter-spacing:-.025em;}
.page-template-service-detail .prodstrip p{margin-top:11px;font-size:14.5px;color:var(--ink-2);line-height:1.6;max-width:44ch;}
.page-template-service-detail .prodstrip .ps-r{display:flex;flex-direction:column;gap:20px;align-items:flex-start;}
.page-template-service-detail .prodstrip .ps-tags{display:flex;flex-wrap:wrap;gap:8px;}
.page-template-service-detail .prodstrip .ps-tags span{font-family:var(--mono);font-size:11px;letter-spacing:.02em;color:var(--ink);border:1px solid var(--line-2);background:var(--paper);border-radius:6px;padding:8px 12px;}
.page-template-service-detail .prodstrip .go{font-size:13px;font-weight:500;color:var(--accent);display:inline-flex;align-items:center;gap:7px;}
.page-template-service-detail .prodstrip .go .ar{display:inline-block;transition:transform .28s cubic-bezier(.2,.7,.2,1);}
.page-template-service-detail .prodstrip:hover .go .ar{transform:translateX(5px);}
.page-template-service-detail .seclab .bar, .page-template-service-detail .ct-seclab .bar, .page-template-service-detail .ab-m .m-seclab .bar, .page-template-service-detail .ab-m .m-ct-seclab .bar{display:none;}
.page-template-service-detail .seclab .n::after, .page-template-service-detail .ct-seclab .n::after, .page-template-service-detail .ab-m .m-seclab .n::after, .page-template-service-detail .ab-m .m-ct-seclab .n::after{content:none;}
.page-template-service-detail .svc-hero .eyebrow{display:flex;align-items:center;gap:12px;margin-bottom:12px;}
.page-template-service-detail .svc-hero .eyebrow .bar{width:26px;height:1px;background:#6b7686;}
.page-template-service-detail .svc-hero .eyebrow .mono{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);;white-space:nowrap;}
/* service-detail responsive · .ab-m spec mapped onto the desktop DOM */
@media (max-width:768px){
  .page-template-service-detail .svc-hero{padding-top:120px;}
  .page-template-service-detail .svc-hero .row{display:block;}
  .page-template-service-detail .svc-hero h1{font-size:40px;}
  .page-template-service-detail .svc-hero .lead{font-size:14px;}
  .page-template-service-detail .svc-hero .meta{border-left:0;padding-left:0;margin-top:26px;padding-top:22px;display:grid;grid-template-columns:1fr 1fr;gap:16px;}
  /* mobile: drop the hairline dividers that read as stray white lines (under the CTA on the hero .meta + between the .pts points) */
  .page-template-service-detail .cb .pts{border-top:0;}
  .page-template-service-detail .cb .pts .pt{border-bottom:0;}
  .page-template-service-detail .svc-heroimg{height:240px;width:auto;max-width:none;margin:0;border:0;border-bottom:1px solid var(--line);}
  .page-template-service-detail .ov-intro{display:block;}
  .page-template-service-detail .ov-h{font-size:26px;}
  .page-template-service-detail .ov-stats{margin-top:18px;border-top:1px solid var(--line);}
  /* workpakket: master/detail stacks, radio interaction kept (artboard mobile
     shows a plus/min accordion; single-DOM compromise, see deviations) */
  .page-template-service-detail .md .cols{grid-template-columns:1fr;}
  .page-template-service-detail .cb{display:flex;flex-direction:column;gap:18px;}
  .page-template-service-detail .cb.flip{display:flex;flex-direction:column-reverse;}
  .page-template-service-detail .cb + .cb{margin-top:36px;}
  .page-template-service-detail .cb .img{min-height:200px;}
  .page-template-service-detail .appr{grid-template-columns:1fr;}
  .page-template-service-detail .appr-head{flex-direction:column;align-items:flex-start;gap:14px;}
  .page-template-service-detail .cases{grid-template-columns:1fr;}
  .page-template-service-detail .other{grid-template-columns:1fr;}
  .page-template-service-detail .prodstrip{grid-template-columns:1fr;gap:18px;padding:20px;}
  .page-template-service-detail .svc-cta .in{padding:24px 20px;}
  .page-template-service-detail .svc-cta h2{font-size:24px;}
  .page-template-service-detail .svc-cta .side{width:100%;}
  .page-template-service-detail .svc-cta .side .btn{width:100%;justify-content:center;}
}
@media (max-width:480px){
  .page-template-service-detail .svc-hero h1{font-size:32px;}
  .page-template-service-detail .ov-h{font-size:23px;}
}
.page-template-service-detail .cases{display:grid;grid-template-columns:1fr 1fr;gap:24px;}

/* ===== services overview (.page-slug-services) ===== */
.page-slug-services .svc{display:grid;grid-template-columns:repeat(6,1fr);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--paper);}
.page-slug-services .tile{position:relative;padding:30px;border-right:1px solid var(--line);border-top:1px solid var(--line);display:flex;flex-direction:column;color:inherit;}
.page-slug-services .tile .chip{position:absolute;top:30px;right:30px;display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);border:1px solid var(--line-2);border-radius:999px;padding:5px 10px;background:var(--paper);}
.page-slug-services .tile .chip .d{width:6px;height:6px;border-radius:50%;background:var(--accent);}
.page-slug-services .tile .chip.kern{color:var(--ink);}
.page-slug-services .tile .chip.kern .d{background:var(--ink);}
.page-slug-services .tags span{font-family:var(--mono);font-size:10px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-2);border:1px solid var(--line);border-radius:5px;padding:4px 8px;}
.page-slug-services .t-mon{grid-column:span 2;grid-row:1;border-top:0;border-right:0;min-height:360px;}
.page-slug-services .t-clean{grid-column:span 2;border-right:0;background:var(--bg-2);}
.page-slug-services .t-ups .frame{position:relative;border:1px solid var(--line);overflow:hidden;min-height:280px;}
.page-slug-services .t-ups .frame .anno{top:12px;left:12px;}
.page-slug-services .prod .frame{position:relative;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;height:380px;background:var(--paper);}
.page-slug-services .prod .frame .anno{top:14px;left:14px;}
.page-slug-services .prod .list .ar{color:var(--ink-3);}
.page-slug-services .case .frame{position:relative;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;height:240px;background:var(--paper);}
.page-slug-services .case .frame .anno{top:12px;left:12px;}
.page-slug-services .eod .lbl .d{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 3px rgba(31,95,214,.14);}
.page-slug-services .tile, .page-slug-services .case{transition:background .3s ease;}
.page-slug-services .tile:hover .go, .page-slug-services .case:hover .go, .page-slug-services .prod .list a:hover .ar{color:var(--accent-ink);}
.page-slug-services .tile:hover .go .ar, .page-slug-services .case:hover .go .ar, .page-slug-services .prod .list a:hover .ar{transform:translateX(5px);}
.page-slug-services .sp-hero{position:relative;padding:148px 0 var(--sec-y);border-bottom:1px solid var(--line);}
.page-slug-services .sp-hero .eyebrow{display:flex;align-items:center;gap:12px;}
.page-slug-services .sp-hero .eyebrow .bar{width:26px;height:1px;background:#6b7686;}
.page-slug-services .sp-hero h1{font-size:64px;line-height:1.02;letter-spacing:-.045em;margin-top:22px;max-width:17ch;}
.page-slug-services .sp-hero .lead{margin-top:24px;font-size:19px;line-height:1.55;color:var(--ink-2);max-width:58ch;}
.page-slug-services .sp-hero .jump{display:flex;gap:12px;margin-top:36px;}
.page-slug-services .sp-hero .jump a{display:inline-flex;align-items:center;gap:10px;border:1px solid var(--line-2);background:var(--paper);border-radius:999px;padding:11px 18px;font-size:14px;font-weight:500;color:var(--ink);transition:border-color .2s,color .2s,box-shadow .2s;}
.page-slug-services .sp-hero .jump a:hover{border-color:var(--accent);color:var(--accent);box-shadow:0 0 0 4px rgba(31,95,214,.1);}
.page-slug-services .sp-hero .jump a .n{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--ink-3);}
.page-slug-services .sp-hero .jump a:hover .n{color:var(--accent);}
.page-slug-services .sp-sec{padding:var(--sec-y) 0;position:relative;isolation:isolate;}
.page-slug-services .sp-sec::before{content:"";position:absolute;top:0;left:0;right:0;height:560px;z-index:-1;pointer-events:none;}
.page-slug-services .sp-sec .sechead{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;margin-bottom:42px;}
.page-slug-services .sp-sec .lhs{display:flex;flex-direction:column;gap:0;max-width:60ch;}
.page-slug-services .sp-sec h2{font-size:38px;letter-spacing:-.03em;}
.page-slug-services .sp-sec .intro{color:var(--ink-2);font-size:16px;line-height:1.6;}
.page-slug-services .sp-card .frame{position:relative;height:204px;overflow:hidden;border-bottom:1px solid var(--line);background:#dcd8cf;}
.page-slug-services .sp-grid.cols4 .sp-card .frame{height:158px;}
.page-slug-services .sp-card .frame .anno{top:12px;left:12px;}
.page-slug-services .sp-card .frame::after{content:"";position:absolute;inset:0;background:linear-gradient(150deg,transparent 46%,rgba(31,95,214,.2));z-index:2;pointer-events:none;}
.page-slug-services .sp-card .body{padding:24px 24px 26px;display:flex;flex-direction:column;flex:1;}
.page-slug-services .sp-card .ix{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;color:var(--ink-3);}
.page-slug-services .sp-card .chip{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:linear-gradient(120deg,#1f5fd6,#5b7bff);border-radius:999px;padding:4px 9px;}
.page-slug-services .sp-card .chip .d{width:6px;height:6px;border-radius:50%;background:#fff;}
.page-slug-services .sp-card .chip.kern{background:linear-gradient(120deg,#2b313c,#4c5563);}
.page-slug-services .sp-card .chip.soft{background:none;color:var(--ink-3);border:1px solid var(--line-2);}
.page-slug-services .sp-card .chip.soft .d{background:var(--ink-3);}
.page-slug-services .sp-card .go{margin-top:auto;padding-top:20px;font-size:13px;font-weight:500;color:var(--accent);display:inline-flex;align-items:center;gap:7px;}
.page-slug-services .sp-card .go .ar{transition:transform .28s cubic-bezier(.2,.7,.2,1);}
.page-slug-services .sp-card:hover .go .ar{transform:translateX(4px);}
.page-slug-services .sp-cta{padding:var(--sec-y) 0;}
.page-slug-services .sp-cta .card{position:relative;overflow:hidden;display:flex;align-items:center;justify-content:space-between;gap:48px;background:radial-gradient(880px 420px at 84% -28%,rgba(31,95,214,.18),transparent 64%),var(--paper);border:1px solid var(--line);border-radius:22px;padding:52px 56px;box-shadow:0 34px 70px -46px rgba(30,42,64,.55);}
.page-slug-services .sp-cta h2{font-size:34px;letter-spacing:-.03em;color:var(--ink);max-width:20ch;margin-top:16px;}
.page-slug-services .sp-cta p{margin-top:14px;color:var(--ink-2);font-size:15px;line-height:1.55;max-width:46ch;}
.page-slug-services .sp-cta .acts{display:flex;gap:12px;flex-shrink:0;}
.page-slug-services .prod .frame{height:472px;}
.page-slug-services .prod .list .rowtext .spec{font-family:var(--mono);font-size:10px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-3);}
.page-slug-services .svc .tile .tags{margin-top:14px;}
.page-slug-services .pc .frame .anno{top:12px;left:12px;}
/* ===== over ons (.page-slug-over-ons) ===== */
.page-slug-over-ons .prod .list .ar{color:var(--ink-3);}
.page-slug-over-ons .case .meta{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);margin-top:16px;}
.page-slug-over-ons .werken .secnum .mono{color:rgba(255,255,255,.6);}
.page-slug-over-ons .werken .sub{margin-top:18px;color:#a8a49b;font-size:15px;line-height:1.65;}
.page-slug-over-ons .werken .cta{margin-top:24px;}
.page-slug-over-ons .werken .call .n{font-family:var(--mono);font-size:12px;color:#7fb0ff;}
.page-slug-over-ons .eod .sub{margin-top:6px;color:var(--ink-2);font-size:14px;}
.page-slug-over-ons .evp-dark .secnum .bar{background:rgba(255,255,255,.4);}
.page-slug-over-ons .evp-dark .secnum .mono{color:rgba(255,255,255,.5);}
.page-slug-over-ons .evp-dark .btn-ghost{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.28);white-space:nowrap;}
.page-slug-over-ons .evp-dark .btn-ghost:hover{color:#cfe0ff;border-color:#7fb0ff;box-shadow:0 0 0 4px rgba(127,176,255,.2),0 0 20px rgba(127,176,255,.34);}
.page-slug-over-ons .hero .rotate{color:#7fb0ff;display:block;transition:opacity .26s ease,transform .26s ease;}
.page-slug-over-ons .hero h1 .hl{display:block;}
.page-slug-over-ons .dlabel .mono{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);white-space:nowrap;}
.page-slug-over-ons .dlabel.ac2 .mono{color:var(--ink-3);}
.page-slug-over-ons .ax .axstat .n{font-family:var(--mono);font-size:26px;font-weight:500;letter-spacing:-.01em;}
.page-slug-over-ons .trk-hr .mono{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);}
.page-slug-over-ons .lv-h>.mono:first-child{flex:1 1 0;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.page-slug-over-ons .lv-h .mono{font-family:var(--mono);font-size:10px;letter-spacing:.04em;color:var(--ink-3);}
.page-slug-over-ons .lv .btn.applybtn, .page-slug-over-ons .sp .btn.applybtn{display:inline-flex;width:fit-content;align-self:flex-end;justify-content:flex-end;gap:6px;background:none;border:0;box-shadow:none;color:var(--accent);padding:3px 0 0;margin-top:1px;font-size:11px;font-weight:500;border-radius:0;}
.page-slug-over-ons .lv .btn.applybtn:hover, .page-slug-over-ons .sp .btn.applybtn:hover{background:none;box-shadow:none;color:var(--accent-ink);}
.page-slug-over-ons .lv-entry .mono{font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);}
.page-slug-over-ons .acad-hero .secnum .bar{background:rgba(255,255,255,.4);}
.page-slug-over-ons .acad-hero .secnum .mono{color:rgba(255,255,255,.5);}
.page-slug-over-ons .acad-trail .cred .c{display:flex;flex-direction:column;gap:3px;}
.page-slug-over-ons .acad-trail .tarrow .m{font-family:var(--mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.4);writing-mode:vertical-rl;transform:rotate(180deg);white-space:nowrap;}
.page-slug-over-ons .tf-col .mono{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);}
.page-slug-over-ons .tf-col .mono.ac{color:var(--accent);}
.page-slug-over-ons .tf-mid .mono{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);writing-mode:vertical-rl;transform:rotate(180deg);}
.page-slug-over-ons .deal-h .t{font-family:var(--sans);font-size:21px;font-weight:600;letter-spacing:-.02em;}
.page-slug-over-ons .deal-h .mono{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);}
.page-slug-over-ons .st-main .mono.ac{font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);}
.page-slug-over-ons .st-row .btn.applybtn{display:inline-flex;width:auto;justify-content:flex-end;align-self:center;gap:6px;background:none;border:0;box-shadow:none;color:var(--accent);padding:0;margin:0;font-size:12.5px;font-weight:500;white-space:nowrap;}
.page-slug-over-ons .st-row .btn.applybtn:hover{background:none;box-shadow:none;color:var(--accent-ink);}
.page-slug-over-ons .st-row .btn.applybtn .ar{transition:transform .2s ease;}
.page-slug-over-ons .st-row .btn.applybtn:hover .ar{transform:translateX(3px);}
.page-slug-over-ons .paths .pth .n{font-family:var(--mono);font-size:30px;font-weight:500;letter-spacing:-.03em;color:var(--line-2);line-height:1;}
.page-slug-over-ons .aud .a-h .mono{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--ink);}
.page-slug-over-ons .testi-q .mono{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);}
.page-slug-over-ons .apply-l .secnum .bar{background:rgba(255,255,255,.4);}
.page-slug-over-ons .apply-l .secnum .mono{color:rgba(255,255,255,.5);}
.page-slug-over-ons .apply-l .intro{color:#9aa3b2;font-size:15px;line-height:1.6;margin-top:16px;max-width:40ch;}
.page-slug-over-ons .apply-contact .val .ar{transition:transform .2s ease;}
.page-slug-over-ons .apply-contact .ac-row:hover .val .ar{transform:translateX(4px);}
.page-slug-over-ons .apply-form .ff .mono{font-family:var(--mono);font-size:10px;letter-spacing:.06em;color:var(--ink-3);flex:none;}
.page-slug-over-ons .apply-form .ff.ta .mono{padding-top:12px;}
.page-slug-over-ons .vchip.on{background:var(--ink);color:#fff;border-color:var(--ink);}
.page-slug-over-ons .vchip.on b{color:#7fb0ff;}
.page-slug-over-ons .vac-glabel .mono{white-space:nowrap;}
.page-slug-over-ons .vac-glabel .dot{width:6px;height:6px;border-radius:50%;background:var(--ink);}
.page-slug-over-ons .vac-glabel .mono{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);}
.page-slug-over-ons .vac-card .vc-go .ar{display:inline-block;transition:transform .2s ease;}
.page-slug-over-ons .vac-card:hover .vc-go .ar{transform:translateX(3px);}
.page-slug-over-ons .vd-hero .btn{margin-top:28px;}
.page-slug-over-ons .vd-fact .k{color:#7fb0ff;}
.page-slug-over-ons .vd-fact .v{font-size:21px;font-weight:600;letter-spacing:-.02em;color:#fff;margin-top:7px;}
.page-slug-over-ons .vd-fact .s{color:#9aa3b2;margin-top:5px;}
.page-slug-over-ons .vd-day .t{font-size:18px;font-weight:600;letter-spacing:-.02em;margin-top:7px;}
.page-slug-over-ons .sal-lead .k{color:var(--ink-3);}
.page-slug-over-ons .sal-line .dot{justify-self:center;position:relative;z-index:1;width:15px;height:15px;border-radius:50%;background:#fff;border:3px solid #1f5fd6;box-shadow:0 0 0 5px rgba(31,95,214,.1);}
.page-slug-over-ons .sal-line .dot.end{box-shadow:0 0 0 5px rgba(31,95,214,.16),0 0 18px rgba(31,95,214,.4);}
.page-slug-over-ons .vd-step .n{font-size:30px;font-weight:500;letter-spacing:-.03em;text-transform:none;color:var(--line-2);line-height:1;}
.page-slug-over-ons .vd-step.trial .n{color:#7fb0ff;}
.page-slug-over-ons .vd-trial-h .mono{color:#7fb0ff;}
.page-slug-over-ons .vd-stat .n{font-size:24px;font-weight:600;letter-spacing:-.03em;}
.page-slug-over-ons .vd-stat .l{margin-top:8px;color:var(--ink-3);}
.page-slug-over-ons .tile:hover .go, .page-slug-over-ons .case:hover .go, .page-slug-over-ons .prod .list a:hover .ar{color:var(--accent-ink);}
.page-slug-over-ons .tile:hover .go .ar, .page-slug-over-ons .case:hover .go .ar, .page-slug-over-ons .prod .list a:hover .ar{transform:translateX(5px);}
.page-slug-over-ons .apply-l .secnum .bar{width:26px;height:1px;background:rgba(255,255,255,.4);}
.page-slug-over-ons .apply-l .secnum .mono{color:rgba(255,255,255,.5);}
.page-slug-over-ons .apply-l .intro{color:#9aa3b2;font-size:15px;line-height:1.62;margin-top:16px;max-width:42ch;}
.page-slug-over-ons .apply-contact .val .ar{transition:transform .2s ease;}
.page-slug-over-ons .apply-contact .ac-row:hover .val .ar{transform:translateX(4px);}
.page-slug-over-ons .apply-form .ff .mono{font-family:var(--mono);font-size:10px;letter-spacing:.06em;color:var(--ink-3);flex:none;}
.page-slug-over-ons .apply-form .ff.ta .mono{padding-top:12px;}
.page-slug-over-ons .apply-form .ff-upload .mono{font-family:var(--mono);font-size:10px;letter-spacing:.06em;color:var(--ink-3);flex:none;}
.page-slug-over-ons .ct-eyebrow .bar{width:26px;height:1px;background:var(--ink-3);}
.page-slug-over-ons .ct-seclab, .page-slug-over-ons .seclab{display:flex;align-items:center;gap:9px;white-space:nowrap;font-family:var(--mono);letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3);}
.page-slug-over-ons .ct-hero .wrap{display:block;}
.page-slug-over-ons .ct-hero .lead{margin-top:24px;font-size:18px;line-height:1.62;color:var(--ink-2);max-width:52ch;}
.page-slug-over-ons .ct-meta .k{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);}
.page-slug-over-ons .ct-meta .v{font-size:15px;color:var(--ink);text-align:right;letter-spacing:-.01em;}
.page-slug-over-ons .ct-visit-info .vcol .k{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);display:block;margin-bottom:10px;}
.page-slug-over-ons .ct-cta .in{display:flex;align-items:center;justify-content:space-between;gap:48px;flex-wrap:wrap;background:radial-gradient(880px 430px at 84% -30%,rgba(31,95,214,.16),transparent 64%),var(--paper);border:1px solid var(--line);border-radius:22px;padding:46px 52px;box-shadow:0 34px 70px -46px rgba(30,42,64,.55);}
.page-slug-over-ons .ct-cta .acts{display:flex;gap:12px;flex-shrink:0;}
.page-slug-over-ons .ab-hero .eyebrow{display:flex;align-items:center;gap:12px;}
.page-slug-over-ons .ab-hero .eyebrow .bar{width:26px;height:1px;background:#6b7686;}
.page-slug-over-ons .ab-hero .eyebrow .mono{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);;white-space:nowrap;}
.page-slug-over-ons .ab-hero .lead{margin-top:24px;font-size:19px;line-height:1.6;color:var(--ink-2);max-width:60ch;}
.page-slug-over-ons .ab-facts-sec{padding:var(--sec-y) 0;}
.page-slug-over-ons .ab-facts{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:#dfe2e7;border:1px solid var(--line-2);border-radius:16px;overflow:hidden;box-shadow:0 30px 62px -40px rgba(30,42,64,.5);}
.page-slug-over-ons .ab-facts .f{background:linear-gradient(165deg,#fafbfc,#ebedf0);padding:26px 24px 24px;display:flex;flex-direction:column;gap:8px;}
.page-slug-over-ons .ab-facts .f .n{font-size:38px;letter-spacing:-.03em;line-height:1;}
.page-slug-over-ons .ab-facts .f .l{font-size:13.5px;color:var(--ink-2);line-height:1.45;}
.page-slug-over-ons .ab-sec{padding:var(--sec-y) 0;position:relative;isolation:isolate;}
.page-slug-over-ons .ab-sec::before{content:"";position:absolute;top:0;left:0;right:0;height:560px;z-index:-1;pointer-events:none;}
.page-slug-over-ons .ab-sec .sechead{display:flex;flex-direction:column;align-items:flex-start;gap:0;max-width:64ch;margin-bottom:42px;}
.page-slug-over-ons .ab-sec .sechead h2{font-size:38px;letter-spacing:-.03em;line-height:1.05;}
.page-slug-over-ons .ab-sec .sechead .intro{font-size:16px;color:var(--ink-2);line-height:1.6;}
.page-slug-over-ons .letter .salut{font-size:18px;color:var(--ink);margin-top:18px;}
.page-slug-over-ons .letter .pull{border-left:3px solid var(--accent);padding:4px 0 4px 26px;margin:32px 0;font-size:22px;line-height:1.5;letter-spacing:-.015em;color:var(--ink);font-weight:500;}
.page-slug-over-ons .letter .pull cite{display:block;margin-top:16px;font-style:normal;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);font-weight:400;}
.page-slug-over-ons .signer .sig{font-size:27px;font-style:italic;font-weight:600;color:var(--accent);letter-spacing:-.02em;line-height:1;}
.page-slug-over-ons .signer .nm{font-size:16px;font-weight:500;margin-top:9px;}
.page-slug-over-ons .vals{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;border-radius:16px;overflow:hidden;background:#dfe2e7;box-shadow:0 30px 62px -40px rgba(30,42,64,.5);}
.page-slug-over-ons .vals .v{background:linear-gradient(165deg,#fafbfc,#ebedf0);padding:26px 24px 28px;display:flex;flex-direction:column;transition:background .3s ease;}
.page-slug-over-ons .vals .v:hover{background:linear-gradient(165deg,#ffffff,#eef2f7);}
.page-slug-over-ons .vals .v .vn{font-family:var(--mono);font-size:30px;font-weight:500;letter-spacing:-.03em;color:var(--line-2);line-height:1;}
.page-slug-over-ons .vals .v h4{margin-top:16px;font-size:18px;font-weight:500;letter-spacing:-.015em;line-height:1.2;}
.page-slug-over-ons .vals .v p{margin-top:9px;font-size:13.5px;color:var(--ink-2);line-height:1.6;}
.page-slug-over-ons .timeline .tl .y{font-family:var(--mono);font-size:26px;font-weight:500;letter-spacing:-.02em;color:var(--accent);line-height:1;}
.page-slug-over-ons .leaders .ld .bd{padding:24px;display:flex;flex-direction:column;}
.page-slug-over-ons .leaders .ld .nm{font-size:20px;letter-spacing:-.02em;margin-top:2px;}
.page-slug-over-ons .certs{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.page-slug-over-ons .certs .c{border:1px solid var(--line);border-radius:14px;background:linear-gradient(165deg,#fcfcfd,#eef1f5);padding:28px;box-shadow:0 16px 34px -28px rgba(30,42,64,.5);}
.page-slug-over-ons .certs .c .k{font-size:22px;letter-spacing:-.02em;}
.page-slug-over-ons .certs .c .v{font-size:14px;color:var(--ink-2);line-height:1.55;margin-top:10px;}
.page-slug-over-ons .ab-cta{padding:0 0 84px;}
.page-slug-over-ons .ab-cta .in{display:flex;align-items:center;justify-content:space-between;gap:48px;flex-wrap:wrap;background:radial-gradient(880px 430px at 84% -30%,rgba(31,95,214,.16),transparent 64%),var(--paper);border:1px solid var(--line);border-radius:22px;padding:48px 52px;box-shadow:0 34px 70px -46px rgba(30,42,64,.55);}
.page-slug-over-ons .ab-cta .kick{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);}
.page-slug-over-ons .ab-cta h2{font-size:32px;letter-spacing:-.03em;max-width:20ch;}
.page-slug-over-ons .ab-cta p{margin-top:12px;color:var(--ink-2);font-size:15px;line-height:1.55;max-width:46ch;}
.page-slug-over-ons .ab-cta .acts{display:flex;flex-direction:column;gap:12px;flex-shrink:0;align-items:stretch;}
.page-slug-over-ons .ab-brief .briefcols{display:grid;grid-template-columns:1.35fr 0.5fr;gap:40px;align-items:start;}
.page-slug-over-ons .paper .lh .brand{font-size:18px;font-weight:600;letter-spacing:-.02em;}
.page-slug-over-ons .paper .lh .meta{font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);text-align:right;line-height:1.7;}
.page-slug-over-ons .paper .salut{font-size:17px;color:var(--ink);max-width:52ch;}
.page-slug-over-ons .paper p.bd{font-size:16px;line-height:1.82;color:var(--ink-2);margin-top:16px;max-width:52ch;}
.page-slug-over-ons .paper p.bd b{color:var(--ink);font-weight:500;}
.page-slug-over-ons .paper .pull{margin:28px 0;padding:2px 0 2px 24px;border-left:3px solid var(--accent);font-size:21px;line-height:1.5;color:var(--ink);font-weight:500;max-width:48ch;}
.page-slug-over-ons .paper .sign{margin-top:36px;padding-top:30px;border-top:1px solid var(--line);display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:center;}
.page-slug-over-ons .person .ph{width:58px;height:58px;border-radius:50%;overflow:hidden;border:2px solid #fff;box-shadow:0 6px 16px -8px rgba(20,25,40,.5),0 0 0 1px var(--line);flex:none;position:relative;}
.page-slug-over-ons .person .sig{font-family:"Caveat",cursive;font-size:31px;line-height:.8;color:var(--ink);}
.page-slug-over-ons .person .nm{font-size:14px;font-weight:500;margin-top:7px;}
.page-slug-over-ons .hand .ar{font-size:20px;}
.page-slug-over-ons .hand .t{font-family:var(--mono);font-size:8.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);}
.page-slug-over-ons .vtl .t{position:relative;padding:0 0 22px 28px;}
.page-slug-over-ons .vtl .t:last-child{padding-bottom:0;}
.page-slug-over-ons .vtl .t::before{content:"";position:absolute;left:-7px;top:3px;width:12px;height:12px;border-radius:50%;background:var(--paper);border:2px solid var(--line-2);}
.page-slug-over-ons .vtl .t.on::before{background:var(--accent);border-color:var(--accent);box-shadow:0 0 0 4px rgba(31,95,214,.16);}
.page-slug-over-ons .vtl .t .y{font-family:var(--mono);font-size:13px;font-weight:500;color:var(--accent);}
.page-slug-over-ons .vtl .t .tt{font-size:14px;font-weight:500;margin-top:3px;letter-spacing:-.01em;}
.page-slug-over-ons .ab-brief .sheet{max-width:760px;margin:10px auto 0;background:var(--paper);border:1px solid var(--line);border-top:3px solid var(--accent);border-radius:6px;overflow:hidden;box-shadow:0 54px 110px -58px rgba(20,25,40,.55);}
.page-slug-over-ons .ab-brief .band{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:24px 56px;border-bottom:1px solid var(--line);}
.page-slug-over-ons .ab-brief .band .brand{display:flex;align-items:center;gap:14px;}
.page-slug-over-ons .ab-brief .band .fc{width:36px;height:36px;border-radius:9px;background:rgba(31,95,214,.08);border:1px solid rgba(31,95,214,.3);color:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;letter-spacing:-.04em;}
.page-slug-over-ons .ab-brief .band .word{font-size:17px;font-weight:700;letter-spacing:-.03em;color:var(--ink);}
.page-slug-over-ons .ab-brief .band .sub{font-family:var(--mono);font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);margin-top:4px;white-space:nowrap;}
.page-slug-over-ons .ab-brief .band .meta{font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);text-align:right;line-height:1.8;white-space:nowrap;}
.page-slug-over-ons .ab-brief .lt{padding:38px 56px 44px;}
.page-slug-over-ons .ab-brief .betreft{display:inline-flex;align-items:center;gap:10px;white-space:nowrap;font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);border:1px solid rgba(31,95,214,.3);background:rgba(31,95,214,.06);border-radius:999px;padding:6px 13px;}
.page-slug-over-ons .ab-brief .betreft .vv{color:var(--ink);}
.page-slug-over-ons .ab-brief .salut{font-family:"Fraunces",Georgia,serif;font-size:22px;font-weight:500;margin-top:24px;}
.page-slug-over-ons .ab-brief .lt p.bd{font-size:15.5px;line-height:1.85;color:var(--ink-2);margin-top:15px;}
.page-slug-over-ons .ab-brief .lt p.bd b{color:var(--ink);font-weight:500;}
.page-slug-over-ons .ab-brief .sign{display:flex;gap:64px;margin-top:34px;padding-top:28px;border-top:1px solid var(--line);}
.page-slug-over-ons .ab-brief .sign .s{display:flex;align-items:center;gap:14px;}
.page-slug-over-ons .ab-brief .sign .s .ph{width:54px;height:54px;border-radius:50%;overflow:hidden;border:2px solid #fff;box-shadow:0 6px 16px -8px rgba(20,25,40,.5),0 0 0 1px var(--line);flex:none;position:relative;background:#dcd8cf;}
.page-slug-over-ons .ab-brief .sign .s .sig{font-family:"Caveat",cursive;font-size:32px;line-height:.8;color:var(--ink);}
.page-slug-over-ons .ab-brief .sign .s .nm{font-size:13.5px;font-weight:500;margin-top:9px;}
.page-slug-over-ons .ab-brief .sign .s .rl{font-family:var(--mono);font-size:9px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);margin-top:3px;}
/* Sign portraits are small circles: the FOTO VOLGT caption can't fit and overflows.
   Show a clean solid placeholder circle (design uses #dcd8cf) until real photos land. */
.page-slug-over-ons .ab-brief .sign .s .ph img{width:100%;height:100%;object-fit:cover;display:block;}
.page-slug-over-ons .ab-brief .briefgrid{display:grid;grid-template-columns:minmax(0,760px) 270px;gap:64px;justify-content:center;align-items:start;margin-top:10px;}
.page-slug-over-ons .ab-brief .briefgrid .sheet{margin:0;}
.page-slug-over-ons .histrail{position:sticky;top:40px;}
.page-slug-over-ons .histrail .rh{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);margin-bottom:20px;}
.page-slug-over-ons .histrail .items{position:relative;}
.page-slug-over-ons .histrail .items::before{content:"";position:absolute;left:4px;top:8px;bottom:8px;width:1px;background:var(--line-2);}
.page-slug-over-ons .histrail .m{position:relative;padding:0 0 24px 26px;}
.page-slug-over-ons .histrail .m:last-child{padding-bottom:0;}
.page-slug-over-ons .histrail .m::before{content:"";position:absolute;left:0;top:5px;width:9px;height:9px;border-radius:50%;background:var(--paper);border:2px solid var(--line-2);}
.page-slug-over-ons .histrail .m.on::before{border-color:var(--accent);background:var(--accent);box-shadow:0 0 0 4px rgba(31,95,214,.14);}
.page-slug-over-ons .histrail .m .y{font-family:var(--mono);font-size:13px;font-weight:500;color:var(--ink);}
.page-slug-over-ons .histrail .m.on .y{color:var(--accent);}
.page-slug-over-ons .histrail .m .t{font-size:12.5px;color:var(--ink-2);line-height:1.5;margin-top:4px;}
.page-slug-over-ons .ab-brief .spk{display:flex;align-items:center;gap:14px;margin-top:30px;font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);white-space:nowrap;}
.page-slug-over-ons .ab-brief .spk::after{content:"";flex:1;height:1px;background:var(--line);}
.page-slug-over-ons .ab-brief .pull{font-family:"Fraunces",Georgia,serif;font-weight:500;font-size:22px;line-height:1.5;letter-spacing:-.01em;color:var(--ink);margin:28px 0;padding:2px 0 2px 26px;border-left:3px solid var(--accent);}
.page-slug-over-ons .ab-brief .pull .by{display:block;margin-top:12px;font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);font-weight:400;}
/* ===== careers / werken-bij (.page-slug-werken-bij) ===== */
.page-slug-werken-bij .tile .chip .d{width:6px;height:6px;border-radius:50%;background:var(--accent);}
.page-slug-werken-bij .tile .chip.kern{color:var(--ink);}
.page-slug-werken-bij .tile .chip.kern .d{background:var(--ink);}
.page-slug-werken-bij .t-ups .frame{position:relative;border:1px solid var(--line);overflow:hidden;min-height:280px;}
.page-slug-werken-bij .t-ups .frame .anno{top:12px;left:12px;}
.page-slug-werken-bij .prod .frame{position:relative;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;height:380px;background:var(--paper);}
.page-slug-werken-bij .prod .frame .anno{top:14px;left:14px;}
.page-slug-werken-bij .prod .list .ar{color:var(--ink-3);}
.page-slug-werken-bij .case .frame{position:relative;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;height:240px;background:var(--paper);}
.page-slug-werken-bij .case .frame .anno{top:12px;left:12px;}
.page-slug-werken-bij .case .meta{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);margin-top:16px;}
.page-slug-werken-bij .werken .secnum .mono{color:rgba(255,255,255,.6);}
.page-slug-werken-bij .werken .cta{margin-top:24px;}
.page-slug-werken-bij .werken .call .n{font-family:var(--mono);font-size:12px;color:#7fb0ff;}
.page-slug-werken-bij .eod .lbl{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);}
.page-slug-werken-bij .eod .lbl .d{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 3px rgba(31,95,214,.14);}
.page-slug-werken-bij .evp-dark{position:relative;border-radius:18px;overflow:hidden;padding:50px 48px 44px;color:#e9e7e2;background:radial-gradient(920px 480px at 82% -14%,rgba(28,41,66,1),rgba(14,17,24,1) 72%);box-shadow:0 44px 90px -46px rgba(14,17,24,.75);}
.page-slug-werken-bij .evp-dark .evp-head{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;margin-bottom:34px;}
.page-slug-werken-bij .evp-dark .evp-head .lhs{display:flex;flex-direction:column;gap:0;}
.page-slug-werken-bij .evp-dark .secnum .bar{background:rgba(255,255,255,.4);}
.page-slug-werken-bij .evp-dark .secnum .mono{color:rgba(255,255,255,.5);}
.page-slug-werken-bij .evp-dark h2{color:#fff;font-size:36px;letter-spacing:-.03em;max-width:24ch;}
.page-slug-werken-bij .evp-dark .evp-sub{font-size:15px;color:#9aa3b2;line-height:1.55;}
.page-slug-werken-bij .evp-dark .btn-ghost{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.28);white-space:nowrap;}
.page-slug-werken-bij .evp-dark .btn-ghost:hover{color:#cfe0ff;border-color:#7fb0ff;box-shadow:0 0 0 4px rgba(127,176,255,.2),0 0 20px rgba(127,176,255,.34);}
.page-slug-werken-bij .evp-idx{border-top:1px solid rgba(255,255,255,.12);}
.page-slug-werken-bij .evp-idx .er{display:grid;grid-template-columns:180px 1fr 340px;gap:40px;align-items:center;padding:26px 16px 26px 6px;border-bottom:1px solid rgba(255,255,255,.1);text-decoration:none;color:inherit;border-radius:10px;transition:background .28s ease;}
.page-slug-werken-bij .evp-idx .er .big{font-family:var(--mono);font-size:88px;font-weight:500;line-height:.8;letter-spacing:-.04em;color:transparent;-webkit-text-stroke:1.5px rgba(127,176,255,.85);transition:color .3s ease,-webkit-text-stroke .3s ease,text-shadow .3s ease;}
.page-slug-werken-bij .evp-idx .er h4{font-size:29px;letter-spacing:-.025em;color:#fff;line-height:1.1;}
.page-slug-werken-bij .evp-idx .er .proof{margin-top:10px;font-family:var(--mono);font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:#9cc0ff;}
.page-slug-werken-bij .evp-idx .er .desc{font-size:14px;color:#9aa3b2;line-height:1.55;}
.page-slug-werken-bij .evp-idx .er:hover{background:linear-gradient(90deg,rgba(31,95,214,.18),rgba(31,95,214,.02));}
.page-slug-werken-bij .evp-idx .er:hover .big{color:#7fb0ff;-webkit-text-stroke:0;text-shadow:0 0 28px rgba(127,176,255,.6);}
.page-slug-werken-bij .prin .role{margin-top:14px;font-family:var(--mono);font-size:11px;letter-spacing:.02em;color:var(--accent);}
.page-slug-werken-bij .hero .rotate{color:#7fb0ff;transition:opacity .28s ease,transform .28s ease;}
.page-slug-werken-bij .hero h1 .hl{display:block;}
.page-slug-werken-bij .gr-head{display:grid;grid-template-columns:1.4fr 1fr;gap:60px;align-items:flex-end;margin:24px 0 44px;}
.page-slug-werken-bij .gr-display{font-size:60px;line-height:.98;letter-spacing:-.035em;font-weight:600;margin:0;}
.page-slug-werken-bij .gr-display .ac{color:var(--accent);}
.page-slug-werken-bij .ac{color:var(--accent);}
.page-slug-werken-bij .dlabel{display:flex;align-items:center;gap:14px;margin:0 0 18px;}
.page-slug-werken-bij .dlabel .dl-bar{width:26px;height:1px;background:#6b7686;flex:none;}
.page-slug-werken-bij .dlabel .mono{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);white-space:nowrap;}
.page-slug-werken-bij .dlabel .cap{font-size:13.5px;color:var(--ink-2);line-height:1.45;max-width:62ch;margin-left:auto;text-align:right;}
.page-slug-werken-bij .dlabel.ac2 .dl-bar{background:#6b7686;}
.page-slug-werken-bij .dlabel.ac2 .mono{color:var(--ink-3);}
.page-slug-werken-bij .gr-axes{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line-2);border:1px solid var(--line-2);border-radius:16px;overflow:hidden;margin-bottom:48px;box-shadow:0 30px 62px -40px rgba(30,42,64,.5);}
.page-slug-werken-bij .ax{padding:34px 36px 0;background:#fff;display:flex;flex-direction:column;min-height:320px;}
.page-slug-werken-bij .ax.alt{background:linear-gradient(165deg,#f4f6f9 0%,#e9edf2 100%);}
.page-slug-werken-bij .ax .axl{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);}
.page-slug-werken-bij .ax h3{margin:18px 0 12px;font-size:34px;font-weight:600;letter-spacing:-.025em;line-height:1.05;}
.page-slug-werken-bij .ax p{margin:0;font-size:14px;color:var(--ink-2);line-height:1.55;max-width:46ch;}
.page-slug-werken-bij .ax .axstat{margin-top:auto;border-top:1px solid var(--line);display:flex;align-items:center;gap:14px;min-height:116px;}
.page-slug-werken-bij .ax .axstat .n{font-family:var(--mono);font-size:26px;font-weight:500;letter-spacing:-.01em;}
.page-slug-werken-bij .ax .axstat .u{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);}
/* carrière-verkenner uitnodiging (vervangt de oude doorgroei-ladder) */
.page-slug-werken-bij .cinv{display:grid;grid-template-columns:1fr 1fr;background:var(--paper);border:1px solid var(--line-2);border-radius:16px;overflow:hidden;box-shadow:0 30px 70px -52px rgba(20,28,44,.5);margin-top:6px;}
.page-slug-werken-bij .cinv > .l{padding:48px 44px;border-right:1px solid var(--line);}
.page-slug-werken-bij .cinv > .l .secnum{margin-bottom:var(--eyb-gap);}
.page-slug-werken-bij .cinv .disp{font-size:38px;line-height:1.06;letter-spacing:-.03em;color:#16181d;font-weight:600;}
.page-slug-werken-bij .cinv .disp .ac{color:var(--accent);}
.page-slug-werken-bij .cinv .sub{margin-top:16px;font-size:15px;line-height:1.6;color:var(--ink-2);max-width:42ch;}
.page-slug-werken-bij .cinv .cta{margin-top:28px;}
.page-slug-werken-bij .cinv .r{padding:22px 30px;display:flex;flex-direction:column;justify-content:center;background:linear-gradient(180deg,#f7f8fa,#eef0f3);}
.page-slug-werken-bij .cinv .pl{display:flex;align-items:center;gap:14px;padding:15px 6px;border-top:1px solid var(--line);transition:padding-left .15s;text-decoration:none;}
.page-slug-werken-bij .cinv .pl:first-child{border-top:0;}
.page-slug-werken-bij .cinv .pl:hover{padding-left:12px;}
.page-slug-werken-bij .cinv .pl .pn{font-size:16px;font-weight:600;letter-spacing:-.015em;color:#16181d;flex:1;}
.page-slug-werken-bij .cinv .pl .arr{color:var(--ink-3);font-size:15px;}
.page-slug-werken-bij .cinv .pl:hover .arr{color:var(--accent);}
.page-slug-werken-bij .cinv .pl-bk{font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);}
.page-slug-werken-bij .cinv .pl-all{display:inline-flex;align-items:center;justify-content:center;gap:8px;align-self:center;margin-top:18px;padding:4px 2px;font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);border-bottom:1px solid rgba(31,95,214,.32);transition:gap .2s,border-color .2s;}
.page-slug-werken-bij .cinv .pl-all:hover{gap:12px;border-color:var(--accent);}
.page-slug-werken-bij .cinv .pl-all .ar{transition:transform .28s cubic-bezier(.2,.7,.2,1);}
.page-slug-werken-bij .cinv .pl-all:hover .ar{transform:translateX(3px);}
@media (max-width:768px){
  .page-slug-werken-bij .cinv{grid-template-columns:1fr;margin-top:2px;}
  .page-slug-werken-bij .cinv > .l{border-right:0;border-bottom:1px solid var(--line);padding:30px 22px;}
  .page-slug-werken-bij .cinv .disp{font-size:30px;}
  .page-slug-werken-bij .cinv .sub{max-width:none;}
  .page-slug-werken-bij .cinv .cta .btn{width:100%;justify-content:center;}
  .page-slug-werken-bij .cinv .r{padding:8px 18px 16px;}
}
.page-slug-werken-bij .ladder{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;align-items:start;margin-bottom:44px;}
.page-slug-werken-bij .trk{border:1px solid var(--line-2);border-radius:14px;overflow:hidden;background:linear-gradient(180deg,#ffffff,#f6f7f9);display:flex;flex-direction:column;}
.page-slug-werken-bij .trk.kern{background:linear-gradient(180deg,#f3f6fb,#e9eef6);border-color:#cdd9ec;}
.page-slug-werken-bij .trk-h{padding:18px 18px 16px;border-bottom:1px solid var(--line);display:flex;flex-direction:column;min-height:164px;}
.page-slug-werken-bij .trk-h .chip-glow, .page-slug-werken-bij .trk-h .allfilled{margin-top:auto;align-self:flex-end;}
.page-slug-werken-bij .trk-hr{display:flex;justify-content:space-between;align-items:baseline;}
.page-slug-werken-bij .trk-hr .mono{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);}
.page-slug-werken-bij .trk-hr .st{color:var(--accent);}
.page-slug-werken-bij .trk-t{font-size:19px;font-weight:600;letter-spacing:-.01em;margin-top:10px;line-height:1.15;}
.page-slug-werken-bij .trk-s{font-size:12.5px;color:var(--ink-2);margin-top:5px;line-height:1.4;min-height:34px;}
.page-slug-werken-bij .chip-glow{display:inline-flex;align-items:center;gap:7px;margin-top:12px;font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);border:1px solid rgba(31,95,214,.32);border-radius:999px;padding:4px 10px;background:rgba(31,95,214,.06);}
.page-slug-werken-bij .chip-glow .dot-pulse{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 7px var(--accent);}
.page-slug-werken-bij .allfilled{display:inline-block;margin-top:12px;font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);}
.page-slug-werken-bij .trk-lv{padding:14px;display:flex;flex-direction:column;flex:1;}
.page-slug-werken-bij .lv{background:#fff;border:1px solid var(--line);border-left:2px solid var(--ink-3);border-radius:8px;padding:11px 12px;display:flex;flex-direction:column;gap:5px;}
.page-slug-werken-bij .lv.open{border-color:rgba(31,95,214,.4);border-left-color:var(--accent);box-shadow:none;}
.page-slug-werken-bij .lv-h{display:flex;align-items:baseline;gap:10px;}
.page-slug-werken-bij .lv-h>.mono:first-child{flex:1 1 0;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.page-slug-werken-bij .lv-h>.op, .page-slug-werken-bij .lv-h>.lvfilled{flex:none;white-space:nowrap;text-align:right;}
.page-slug-werken-bij .lv-h .mono{font-family:var(--mono);font-size:10px;letter-spacing:.04em;color:var(--ink-3);}
.page-slug-werken-bij .lv-h .lvfilled{font-family:var(--mono);font-size:9px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);}
.page-slug-werken-bij .lv-h .op{font-family:var(--mono);font-size:9px;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);}
.page-slug-werken-bij .lv-t{font-size:14px;font-weight:600;letter-spacing:-.008em;line-height:1.18;}
.page-slug-werken-bij .lv-sal{font-family:var(--mono);font-size:11.5px;font-weight:500;color:var(--ink);}
.page-slug-werken-bij .lv-sal span{color:var(--ink-3);font-weight:400;}
.page-slug-werken-bij .lv .btn.applybtn, .page-slug-werken-bij .sp .btn.applybtn{display:inline-flex;width:fit-content;align-self:flex-end;justify-content:flex-end;gap:6px;background:none;border:0;box-shadow:none;color:var(--accent);padding:3px 0 0;margin-top:1px;font-size:11px;font-weight:500;border-radius:0;}
.page-slug-werken-bij .lv .btn.applybtn:hover, .page-slug-werken-bij .sp .btn.applybtn:hover{background:none;box-shadow:none;color:var(--accent-ink);}
.page-slug-werken-bij .up{display:flex;justify-content:center;padding:7px 0;color:var(--ink-3);font-family:var(--mono);font-size:14px;}
.page-slug-werken-bij .lv-entry{margin-top:12px;padding-top:12px;border-top:1px dashed var(--line-2);display:flex;align-items:center;justify-content:space-between;gap:10px;}
.page-slug-werken-bij .lv-entry .mono{font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);}
.page-slug-werken-bij .support{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;}
.page-slug-werken-bij .sp{background:linear-gradient(165deg,#fafbfc,#eef0f3);border:1px solid var(--line);border-left:2px solid var(--ink-3);border-radius:10px;padding:14px;display:flex;flex-direction:column;gap:6px;}
.page-slug-werken-bij .sp.open{border-color:rgba(31,95,214,.4);border-left-color:var(--accent);box-shadow:none;}
.page-slug-werken-bij .vac-cta{display:flex;justify-content:center;margin-top:44px;}
.page-slug-werken-bij .week{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;border-radius:16px;overflow:hidden;box-shadow:0 30px 62px -40px rgba(30,42,64,.5);background:#dfe2e7;}
.page-slug-werken-bij .week .day{background:linear-gradient(165deg,#fafbfc 0%,#ebedf0 100%);padding:26px 20px 22px;min-height:230px;display:flex;flex-direction:column;}
.page-slug-werken-bij .week .day .d{font-family:var(--mono);font-size:30px;font-weight:500;letter-spacing:-.03em;color:var(--line-2);line-height:1;}
.page-slug-werken-bij .week .day h4{margin:16px 0 0;font-size:15px;font-weight:600;letter-spacing:-.005em;line-height:1.25;}
.page-slug-werken-bij .week .day p{margin:8px 0 0;font-size:12.5px;color:var(--ink-2);line-height:1.5;flex:1;}
.page-slug-werken-bij .week .day .loc{margin-top:14px;font-family:var(--mono);font-size:9.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--accent);}
.page-slug-werken-bij .week-note{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);}
.page-slug-werken-bij .acad{background:none;}
.page-slug-werken-bij .acad-hero{border-radius:20px;overflow:hidden;background:radial-gradient(900px 520px at 16% -24%,rgba(31,46,74,1),rgba(12,15,22,1) 76%);color:#e9e7e2;padding:46px;display:grid;grid-template-columns:.78fr 1.22fr;gap:48px;align-items:center;box-shadow:0 50px 100px -50px rgba(8,11,18,.8);margin-bottom:40px;}
.page-slug-werken-bij .acad-hero .secnum .bar{background:rgba(255,255,255,.4);}
.page-slug-werken-bij .acad-hero .secnum .mono{color:rgba(255,255,255,.5);}
.page-slug-werken-bij .acad-hero .gr-display{color:#fff;font-size:42px;margin-top:16px;}
.page-slug-werken-bij .acad-hero .gr-display .ac{color:#7fb0ff;}
.page-slug-werken-bij .acad-hero .hero-lead{color:#9aa3b2;font-size:15px;line-height:1.6;margin-top:18px;max-width:38ch;}
.page-slug-werken-bij .acad-trail{display:flex;flex-direction:column;}
.page-slug-werken-bij .acad-trail .trail-h{display:flex;align-items:center;gap:9px;margin-bottom:16px;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:#7fb0ff;}
.page-slug-werken-bij .acad-trail .trail-h .dot-pulse{width:7px;height:7px;border-radius:50%;background:#7fb0ff;box-shadow:0 0 8px #7fb0ff;}
.page-slug-werken-bij .acad-trail .cred{display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:start;padding:12px 0;border-top:1px solid rgba(255,255,255,.1);}
.page-slug-werken-bij .acad-trail .cred .d{width:7px;height:7px;border-radius:50%;background:#7fb0ff;box-shadow:0 0 8px #7fb0ff;margin-top:7px;}
.page-slug-werken-bij .acad-trail .cred .c{display:flex;flex-direction:column;gap:3px;}
.page-slug-werken-bij .acad-trail .cred .to{font-size:15px;color:#fff;font-weight:600;letter-spacing:-.01em;line-height:1.2;}
.page-slug-werken-bij .acad-trail .cred .from{font-family:var(--mono);font-size:10.5px;letter-spacing:.02em;color:rgba(255,255,255,.42);}
.page-slug-werken-bij .acad-trail .tfpair{display:grid;grid-template-columns:1fr auto 1fr;gap:18px;align-items:center;}
.page-slug-werken-bij .acad-trail .tcard{border-radius:14px;padding:22px;}
.page-slug-werken-bij .acad-trail .tcard.now{border:1px dashed rgba(255,255,255,.2);background:rgba(255,255,255,.02);}
.page-slug-werken-bij .acad-trail .tcard.then{border:1px solid rgba(127,176,255,.35);background:linear-gradient(165deg,rgba(127,176,255,.12),rgba(127,176,255,.03));}
.page-slug-werken-bij .acad-trail .tcard .th{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;margin-bottom:14px;}
.page-slug-werken-bij .acad-trail .tcard.now .th{color:rgba(255,255,255,.45);}
.page-slug-werken-bij .acad-trail .tcard.then .th{color:#7fb0ff;}
.page-slug-werken-bij .acad-trail .tcard ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:9px;}
.page-slug-werken-bij .acad-trail .tcard.now li{font-size:13.5px;color:rgba(255,255,255,.6);}
.page-slug-werken-bij .acad-trail .tcard.then li{font-size:14px;color:#fff;font-weight:600;letter-spacing:-.005em;}
.page-slug-werken-bij .acad-trail .tarrow{display:flex;flex-direction:column;align-items:center;gap:8px;color:#7fb0ff;}
.page-slug-werken-bij .acad-trail .tarrow .big{font-size:24px;font-family:var(--mono);}
.page-slug-werken-bij .acad-trail .tarrow .m{font-family:var(--mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.4);writing-mode:vertical-rl;transform:rotate(180deg);white-space:nowrap;}
.page-slug-werken-bij .acad .secnum{margin-bottom:0;}
.page-slug-werken-bij .tf-col .mono{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);}
.page-slug-werken-bij .tf-col .mono.ac{color:var(--accent);}
.page-slug-werken-bij .tf-mid .mono{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);writing-mode:vertical-rl;transform:rotate(180deg);}
.page-slug-werken-bij .programs{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:1px;border-radius:16px;overflow:hidden;box-shadow:0 30px 62px -40px rgba(30,42,64,.5);background:#dfe2e7;margin-bottom:64px;}
.page-slug-werken-bij .prog{grid-column:auto;background:linear-gradient(165deg,#fafbfc 0%,#ebedf0 100%);padding:26px 20px 22px;display:flex;flex-direction:column;text-decoration:none;color:inherit;min-height:248px;transition:background .3s ease;}
.page-slug-werken-bij .prog.wide{grid-column:auto;}
.page-slug-werken-bij .prog:hover{background:linear-gradient(165deg,#ffffff 0%,#eef2f7 100%);}
.page-slug-werken-bij .prog .bn{font-family:var(--mono);font-size:30px;font-weight:500;letter-spacing:-.03em;color:var(--line-2);line-height:1;}
.page-slug-werken-bij .prog h4{margin:16px 0 0;font-size:17px;font-weight:600;letter-spacing:-.015em;line-height:1.15;}
.page-slug-werken-bij .prog p{margin:8px 0 0;font-size:12px;color:var(--ink-2);line-height:1.5;flex:1;}
.page-slug-werken-bij .prog .pay{margin-top:14px;font-family:var(--mono);font-size:9.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--accent);}
.page-slug-werken-bij .deal{display:grid;grid-template-columns:1fr 1fr;gap:1px;border-radius:16px;overflow:hidden;box-shadow:0 30px 62px -40px rgba(30,42,64,.5);background:#dfe2e7;margin-bottom:64px;}
.page-slug-werken-bij .deal-col{background:#fff;padding:32px 36px 36px;}
.page-slug-werken-bij .deal-col.alt{background:linear-gradient(165deg,#f4f6f9,#e9edf2);}
.page-slug-werken-bij .deal-h{display:flex;align-items:baseline;gap:12px;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--line-2);}
.page-slug-werken-bij .deal-h .t{font-family:var(--sans);font-size:21px;font-weight:600;letter-spacing:-.02em;}
.page-slug-werken-bij .deal-h .mono{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);}
.page-slug-werken-bij .deal-col ul{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:14px;}
.page-slug-werken-bij .deal-col li{display:grid;grid-template-columns:170px 1fr;gap:16px;align-items:baseline;}
.page-slug-werken-bij .deal-col .dk{font-family:var(--mono);font-size:12px;letter-spacing:.04em;text-transform:uppercase;color:var(--accent);}
.page-slug-werken-bij .deal-col .dv{font-size:15px;color:var(--ink);line-height:1.4;}
.page-slug-werken-bij .starters{border:1px solid var(--line-2);border-radius:16px;overflow:hidden;background:#fff;box-shadow:0 30px 62px -40px rgba(30,42,64,.5);}
.page-slug-werken-bij .st-row{display:grid;grid-template-columns:34px minmax(0,1.5fr) minmax(0,1.6fr) 120px 138px;gap:24px;align-items:center;padding:18px 26px;border-top:1px solid var(--line);}
.page-slug-werken-bij .st-row:first-child{border-top:0;}
.page-slug-werken-bij .st-n{font-family:var(--mono);font-size:11px;color:var(--ink-3);letter-spacing:.06em;}
.page-slug-werken-bij .st-main .mono.ac{font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);}
.page-slug-werken-bij .st-t{display:flex;align-items:center;gap:9px;font-size:16px;font-weight:600;letter-spacing:-.01em;margin-top:5px;line-height:1.15;}
.page-slug-werken-bij .st-t .chip-glow{margin-top:0;}
.page-slug-werken-bij .st-t .lvfilled{font-family:var(--mono);font-size:9px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);}
.page-slug-werken-bij .st-note{font-size:12.5px;color:var(--ink-2);line-height:1.45;}
.page-slug-werken-bij .st-pay{font-family:var(--mono);font-size:13px;font-weight:500;text-align:right;white-space:nowrap;}
.page-slug-werken-bij .apply-off{font-size:12px;color:var(--ink-3);font-weight:500;opacity:.55;white-space:nowrap;text-align:right;}
.page-slug-werken-bij .st-row .btn.applybtn{display:inline-flex;width:auto;justify-content:flex-end;align-self:center;gap:6px;background:none;border:0;box-shadow:none;color:var(--accent);padding:0;margin:0;font-size:12.5px;font-weight:500;white-space:nowrap;}
.page-slug-werken-bij .st-row .btn.applybtn:hover{background:none;box-shadow:none;color:var(--accent-ink);}
.page-slug-werken-bij .st-row .btn.applybtn .ar{transition:transform .2s ease;}
.page-slug-werken-bij .st-row .btn.applybtn:hover .ar{transform:translateX(3px);}
/* ===== Academy (sectie 04) · volledige donkere band (design tweak). Kaarten houden hun fc-cardgrid vorm; alleen kleuren worden donker. ===== */
.page-slug-werken-bij .acad{background:radial-gradient(900px 520px at 84% -16%,rgba(28,41,66,1),rgba(12,15,20,1) 70%);border-top:1px solid rgba(255,255,255,.06);}
.page-slug-werken-bij .acad .acad-hero{background:transparent;border-radius:0;padding:0 0 6px;box-shadow:none;}
.page-slug-werken-bij .acad .acad-hero .secnum{margin-bottom:var(--eyb-gap);}
/* eyebrows -> opvallende titels */
.page-slug-werken-bij .acad .dlabel.ac2{flex-direction:column;align-items:flex-start;gap:7px;margin-top:8px;}
.page-slug-werken-bij .acad .dlabel.ac2 .dl-bar{display:none;}
.page-slug-werken-bij .acad .dlabel.ac2 .mono{font-family:var(--sans);font-size:27px;font-weight:600;letter-spacing:-.025em;text-transform:none;color:#fff;}
/* programs dark */
.page-slug-werken-bij .acad .programs.fc-cardgrid .prog{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.12);}
.page-slug-werken-bij .acad .programs.fc-cardgrid .prog:hover{background:rgba(127,176,255,.1);border-color:rgba(127,176,255,.4);}
.page-slug-werken-bij .acad .prog{color:#e9edf3;}
.page-slug-werken-bij .acad .prog .bn{color:transparent;-webkit-text-stroke:1.4px #7fb0ff;}
.page-slug-werken-bij .acad .prog:hover .bn{color:#7fb0ff;-webkit-text-stroke:0;text-shadow:0 0 20px rgba(127,176,255,.7);}
.page-slug-werken-bij .acad .prog h4{color:#fff;}
.page-slug-werken-bij .acad .prog p{color:rgba(255,255,255,.6);}
.page-slug-werken-bij .acad .prog .pay{color:#7fb0ff;}
/* deal dark */
.page-slug-werken-bij .acad .deal.fc-cardgrid .deal-col,
.page-slug-werken-bij .acad .deal.fc-cardgrid .deal-col.alt{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.12);}
.page-slug-werken-bij .acad .deal.fc-cardgrid .deal-col:hover{background:rgba(127,176,255,.1);border-color:rgba(127,176,255,.4);}
.page-slug-werken-bij .acad .deal-h{border-bottom-color:rgba(255,255,255,.14);}
.page-slug-werken-bij .acad .deal-h .t{color:#fff;}
.page-slug-werken-bij .acad .deal-h .mono{color:rgba(255,255,255,.5);}
.page-slug-werken-bij .acad .deal-col .dk{color:#7fb0ff;}
.page-slug-werken-bij .acad .deal-col .dv{color:rgba(255,255,255,.82);}
/* starters dark */
.page-slug-werken-bij .acad .starters{background:rgba(255,255,255,.04);border-color:rgba(255,255,255,.12);box-shadow:0 40px 80px -50px rgba(0,0,0,.8);}
.page-slug-werken-bij .acad .st-row{border-top-color:rgba(127,176,255,.16);}
.page-slug-werken-bij .acad .st-n{color:rgba(255,255,255,.4);}
.page-slug-werken-bij .acad .st-t{color:#fff;}
.page-slug-werken-bij .acad .st-t .lvfilled{color:rgba(255,255,255,.45);}
.page-slug-werken-bij .acad .st-note{color:rgba(255,255,255,.6);}
.page-slug-werken-bij .acad .st-pay{color:#fff;}
.page-slug-werken-bij .acad .apply-off{color:rgba(255,255,255,.4);}
.page-slug-werken-bij .paths{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1px;border-radius:16px;overflow:hidden;box-shadow:0 30px 62px -40px rgba(30,42,64,.5);background:#dfe2e7;}
.page-slug-werken-bij .paths .pth{background:linear-gradient(165deg,#fafbfc 0%,#ebedf0 100%);padding:26px 22px 22px;min-height:232px;display:flex;flex-direction:column;text-decoration:none;color:inherit;transition:background .3s ease;}
.page-slug-werken-bij .paths .pth:hover{background:linear-gradient(165deg,#ffffff 0%,#eef2f7 100%);}
.page-slug-werken-bij .paths .pth .n{font-family:var(--mono);font-size:30px;font-weight:500;letter-spacing:-.03em;color:var(--line-2);line-height:1;}
.page-slug-werken-bij .paths .pth h4{margin:16px 0 0;font-size:17px;font-weight:600;letter-spacing:-.01em;line-height:1.2;}
.page-slug-werken-bij .paths .pth p{margin:8px 0 0;font-size:12.5px;color:var(--ink-2);line-height:1.5;}
.page-slug-werken-bij .paths .pth .role{margin-top:auto;padding-top:12px;font-family:var(--mono);font-size:11px;letter-spacing:.02em;color:var(--accent);}
.page-slug-werken-bij .aud .a-h .mono{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--ink);}
.page-slug-werken-bij .testi{display:grid;grid-template-columns:1.4fr 1fr;gap:60px;align-items:center;}
.page-slug-werken-bij .testi-q .mono{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);}
.page-slug-werken-bij .testi .quote{margin:0;font-size:32px;line-height:1.28;letter-spacing:-.02em;font-weight:500;}
.page-slug-werken-bij .testi .quote-attr{margin-top:20px;font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);}
.page-slug-werken-bij .testi-ph{position:relative;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;height:320px;background:var(--paper);box-shadow:0 18px 40px -26px rgba(30,42,64,.5);}
.page-slug-werken-bij .apply-panel{display:grid;grid-template-columns:1fr 1fr;align-items:stretch;border-radius:18px;overflow:hidden;box-shadow:0 44px 90px -46px rgba(14,17,24,.75);}
.page-slug-werken-bij .apply-l{padding:46px 44px;display:flex;flex-direction:column;color:#e9e7e2;background:radial-gradient(860px 460px at 14% -18%,rgba(28,41,66,1),rgba(14,17,24,1) 72%);}
.page-slug-werken-bij .apply-l .secnum .bar{background:rgba(255,255,255,.4);}
.page-slug-werken-bij .apply-l .secnum .mono{color:rgba(255,255,255,.5);}
.page-slug-werken-bij .apply-l h2{color:#fff;font-size:40px;letter-spacing:-.03em;margin-top:16px;line-height:1.0;}
.page-slug-werken-bij .apply-l .intro{color:#9aa3b2;font-size:15px;line-height:1.6;margin-top:16px;max-width:40ch;}
.page-slug-werken-bij .apply-contact{margin-top:auto;padding-top:30px;display:flex;flex-direction:column;}
.page-slug-werken-bij .apply-contact .ac-row{display:flex;flex-direction:column;gap:4px;padding:16px 0;border-top:1px solid rgba(255,255,255,.12);text-decoration:none;transition:padding-left .25s ease;}
.page-slug-werken-bij .apply-contact .ac-row:last-child{border-bottom:1px solid rgba(255,255,255,.12);}
.page-slug-werken-bij .apply-contact .lbl{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:#9cc0ff;}
.page-slug-werken-bij .apply-contact .num{font-family:var(--mono);font-size:23px;font-weight:500;color:#fff;letter-spacing:-.01em;}
.page-slug-werken-bij .apply-contact .val{font-size:16px;color:#fff;display:inline-flex;align-items:center;gap:8px;}
.page-slug-werken-bij .apply-contact .val .ar{transition:transform .2s ease;}
.page-slug-werken-bij .apply-contact .ac-row:hover .num{color:#cfe0ff;}
.page-slug-werken-bij .apply-contact .ac-row:hover .val{color:#cfe0ff;}
.page-slug-werken-bij .apply-contact .ac-row:hover .val .ar{transform:translateX(4px);}
.page-slug-werken-bij .apply-form{background:#fff;padding:38px 36px;border:0;border-radius:0;box-shadow:none;display:flex;flex-direction:column;justify-content:center;}
.page-slug-werken-bij .apply-form .ff-label{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);margin-bottom:14px;}
.page-slug-werken-bij .apply-form .ff{display:flex;align-items:center;gap:12px;margin-top:10px;border:1px solid var(--line);border-radius:8px;background:var(--bg-2);padding:0 14px;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease;}
.page-slug-werken-bij .apply-form .ff:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px rgba(31,95,214,.12);background:#fff;}
.page-slug-werken-bij .apply-form .ff .mono{font-family:var(--mono);font-size:10px;letter-spacing:.06em;color:var(--ink-3);flex:none;}
.page-slug-werken-bij .apply-form .ff input, .page-slug-werken-bij .apply-form .ff textarea{flex:1;min-width:0;border:0;background:none;padding:12px 0;font-family:var(--sans);font-size:14px;color:var(--ink);}
.page-slug-werken-bij .apply-form .ff input:focus, .page-slug-werken-bij .apply-form .ff textarea:focus{outline:none;}
.page-slug-werken-bij .apply-form .ff.ta{align-items:flex-start;}
.page-slug-werken-bij .apply-form .ff.ta .mono{padding-top:12px;}
.page-slug-werken-bij .apply-form .ff textarea{min-height:76px;resize:vertical;}
.page-slug-werken-bij .apply-form .ff-submit{width:auto;align-self:center;justify-content:center;margin-top:24px;padding:11px 26px;}
.page-slug-werken-bij .eod-lbl .d{width:7px;height:7px;border-radius:50%;background:#7fb0ff;box-shadow:0 0 0 3px rgba(127,176,255,.2);}
.page-slug-werken-bij .tile:hover .go, .page-slug-werken-bij .case:hover .go, .page-slug-werken-bij .prod .list a:hover .ar{color:var(--accent-ink);}
.page-slug-werken-bij .tile:hover .go .ar, .page-slug-werken-bij .case:hover .go .ar, .page-slug-werken-bij .prod .list a:hover .ar{transform:translateX(5px);}
/* Group 2 responsive · 390-artboard spec mapped to breakpoints */
@media (max-width:768px){
  .page-slug-services .sp-hero{padding-top:120px;}
  .page-slug-services .sp-hero h1{font-size:38px;}
  .page-slug-services .svc{display:flex;flex-direction:column;}
  .page-slug-services .sp-grid,.page-slug-services .sp-grid.cols4{grid-template-columns:1fr;}
  .page-slug-services .sp-cta .in{padding:24px 20px;}
  .page-slug-over-ons .vals,.page-slug-over-ons .certs{grid-template-columns:1fr;}
  .page-slug-over-ons .ab-brief .briefcols,.page-slug-over-ons .ab-brief .briefgrid{grid-template-columns:1fr;}
  .page-slug-over-ons .paper .sign{grid-template-columns:1fr;}
  .page-slug-over-ons .tl-row{display:block;}
  .page-slug-werken-bij .evp-idx .er{display:block;padding:18px 0;}
  .page-slug-werken-bij .gr-head,.page-slug-werken-bij .gr-axes{grid-template-columns:1fr;}
  .page-slug-werken-bij .ladder,.page-slug-werken-bij .programs{grid-template-columns:1fr;}
  .page-slug-werken-bij .support{grid-template-columns:1fr;}
  .page-slug-werken-bij .week{grid-template-columns:1fr 1fr;}
  .page-slug-werken-bij .acad-hero{grid-template-columns:1fr;padding:24px 20px;}
  .page-slug-werken-bij .acad-trail .tfpair{grid-template-columns:1fr;}
}
@media (max-width:480px){
  .page-slug-services .sp-hero h1{font-size:32px;}
  .page-slug-werken-bij .week{grid-template-columns:1fr;}
}

/* ===== over ons / about · mobile (390 artboard -> breakpoints) [overons-mobile-v1] =====
   Ports the design's .ab-m over-ons reflow onto the desktop DOM. Later in source
   order than the brief group-2 stub above, so equal-specificity rules win. */
@media (max-width:768px){
  /* section rhythm */
  .page-slug-over-ons .ab-sec{padding:var(--sec-y) 0;}
  .page-slug-over-ons .ab-sec::before{height:340px;}
  .page-slug-over-ons .ab-sec .sechead{margin-bottom:26px;}
  .page-slug-over-ons .ab-sec .sechead h2{font-size:24px;margin-top:10px;}
  .page-slug-over-ons .ab-sec .sechead .intro{font-size:13.5px;}
  .page-slug-over-ons .ab-facts-sec{padding:var(--sec-y) 0;}
  .page-slug-over-ons .ab-facts{grid-template-columns:1fr 1fr;border-radius:14px;}
  .page-slug-over-ons .ab-facts .f{padding:18px 16px;}
  .page-slug-over-ons .ab-facts .f .n{font-size:30px;}

  /* 01 · brief (founder letter) */
  .page-slug-over-ons .ab-brief .briefgrid{grid-template-columns:1fr;gap:18px;margin-top:6px;}
  .page-slug-over-ons .ab-brief .sheet{max-width:none;margin:14px 0 0;}
  .page-slug-over-ons .ab-brief .band{padding:14px 18px;gap:14px;}
  .page-slug-over-ons .ab-brief .band .fc{width:30px;height:30px;font-size:11px;}
  .page-slug-over-ons .ab-brief .band .word{font-size:14px;}
  .page-slug-over-ons .ab-brief .band .sub{font-size:8px;}
  .page-slug-over-ons .ab-brief .band .meta{font-size:8.5px;}
  .page-slug-over-ons .ab-brief .lt{padding:18px 18px 22px;}
  .page-slug-over-ons .ab-brief .salut{font-size:18px;margin-top:16px;}
  .page-slug-over-ons .ab-brief .lt p.bd{font-size:14px;line-height:1.7;margin-top:12px;}
  .page-slug-over-ons .ab-brief .pull{font-size:17px;margin:18px 0;padding:2px 0 2px 16px;}
  .page-slug-over-ons .ab-brief .pull .by{font-size:9px;margin-top:9px;}
  .page-slug-over-ons .ab-brief .spk{margin-top:20px;}
  .page-slug-over-ons .ab-brief .sign{gap:24px;margin-top:22px;padding-top:18px;flex-wrap:wrap;}
  .page-slug-over-ons .ab-brief .sign .s{gap:11px;}
  .page-slug-over-ons .ab-brief .sign .s .ph{width:44px;height:44px;}
  .page-slug-over-ons .ab-brief .sign .s .sig{font-size:26px;}
  .page-slug-over-ons .ab-brief .sign .s .nm{font-size:12.5px;}
  .page-slug-over-ons .ab-brief .sign .s .rl{font-size:8.5px;}
  /* history trail -> design's m-histrail: compact milestone chips (tidy 2-col grid),
     no vertical rail, small borderless dots. */
  .page-slug-over-ons .histrail{position:static;top:auto;margin-top:0;border-top:1px solid var(--line);padding-top:16px;}
  .page-slug-over-ons .histrail .rh{margin-bottom:14px;}
  .page-slug-over-ons .histrail .items{display:grid;grid-template-columns:1fr 1fr;gap:14px 18px;}
  .page-slug-over-ons .histrail .items::before{display:none;}
  .page-slug-over-ons .histrail .m{padding:0 0 0 15px;}
  .page-slug-over-ons .histrail .m::before{top:4px;width:8px;height:8px;background:var(--line-2);border:0;}
  .page-slug-over-ons .histrail .m.on::before{background:var(--accent);border:0;box-shadow:none;}
  .page-slug-over-ons .histrail .m .y{font-size:11px;}
  .page-slug-over-ons .histrail .m .t{font-size:10px;color:var(--ink-3);margin-top:2px;line-height:1.35;}

  /* 02 · values (design m-vals: stacked, hairline-separated) */
  .page-slug-over-ons .vals{grid-template-columns:1fr;border-radius:12px;}
  .page-slug-over-ons .vals .v{padding:18px;}
  .page-slug-over-ons .vals .v .vn{font-size:22px;}
  .page-slug-over-ons .vals .v h4{font-size:16px;margin-top:8px;}
  .page-slug-over-ons .vals .v p{font-size:13px;margin-top:7px;}

  /* 03 · certifications (design m-certs) */
  .page-slug-over-ons .certs{grid-template-columns:1fr;gap:10px;}
  .page-slug-over-ons .certs .c{padding:16px;border-radius:11px;}
  .page-slug-over-ons .certs .c .k{font-size:18px;}
  .page-slug-over-ons .certs .c .v{font-size:13px;margin-top:7px;}

  /* closing CTA */
  .page-slug-over-ons .ab-cta{padding:0 0 44px;}
  .page-slug-over-ons .ab-cta .in{flex-direction:column;align-items:flex-start;gap:20px;padding:24px 22px;border-radius:16px;}
  .page-slug-over-ons .ab-cta h2{font-size:22px;}
  .page-slug-over-ons .ab-cta p{font-size:13px;}
  .page-slug-over-ons .ab-cta .acts{width:100%;}
  .page-slug-over-ons .ab-cta .acts .btn{width:100%;justify-content:center;}
}
@media (max-width:480px){
  .page-slug-over-ons .ab-brief .sign{gap:18px;}
  .page-slug-over-ons .ab-sec .sechead h2{font-size:23px;}
}
/* ===== careers / werken-bij · mobile (390 artboard -> breakpoints) [careers-mobile-v2] =====
   Completes the brief reflow stub above by porting the design's mobile (.ab-m,
   m-* spec) sizing/stacking onto the desktop DOM. Later in source order than the
   stub, so equal-specificity rules here win on conflict. */
@media (max-width:768px){
  /* 01 · EVP dark */
  .page-slug-werken-bij .evp-dark{padding:26px 20px 24px;border-radius:16px;}
  .page-slug-werken-bij .evp-dark .evp-head{flex-direction:column;align-items:flex-start;gap:16px;margin-bottom:18px;}
  .page-slug-werken-bij .evp-dark h2{font-size:24px;}
  .page-slug-werken-bij .evp-dark .evp-head .btn{width:100%;justify-content:center;}
  .page-slug-werken-bij .evp-idx .er{display:block;padding:18px 0;}
  .page-slug-werken-bij .evp-idx .er .big{font-size:46px;}
  .page-slug-werken-bij .evp-idx .er h4{font-size:19px;margin-top:12px;}
  .page-slug-werken-bij .evp-idx .er .proof{font-size:10px;}
  .page-slug-werken-bij .evp-idx .er .desc{font-size:13px;margin-top:10px;}

  /* 02 · Doorgroeipaden intro + axes */
  .page-slug-werken-bij .gr-head{grid-template-columns:1fr;gap:16px;margin:14px 0 24px;}
  .page-slug-werken-bij .gr-display{font-size:34px;}
  .page-slug-werken-bij .gr-axes{grid-template-columns:1fr;border-radius:14px;margin-bottom:24px;}
  .page-slug-werken-bij .ax{padding:22px;min-height:0;}
  .page-slug-werken-bij .ax h3{font-size:24px;margin:10px 0 8px;}
  .page-slug-werken-bij .ax p{font-size:13px;}
  .page-slug-werken-bij .ax .axstat{min-height:0;margin-top:14px;padding-top:12px;gap:10px;}
  .page-slug-werken-bij .ax .axstat .n{font-size:17px;}
  .page-slug-werken-bij .ax .axstat .u{font-size:10px;}

  /* divider labels: caption drops below the mono label */
  .page-slug-werken-bij .dlabel{flex-wrap:wrap;gap:8px 12px;margin:24px 0 12px;}
  .page-slug-werken-bij .dlabel .cap{margin-left:0;text-align:left;flex-basis:100%;font-size:12px;}

  /* ladder + support */
  .page-slug-werken-bij .ladder{grid-template-columns:1fr;gap:12px;margin-bottom:24px;}
  .page-slug-werken-bij .trk-h{min-height:0;}
  .page-slug-werken-bij .trk-s{min-height:0;}
  .page-slug-werken-bij .support{grid-template-columns:1fr;gap:8px;}

  /* 03 · week op locatie */
  .page-slug-werken-bij .week{grid-template-columns:1fr 1fr;}
  .page-slug-werken-bij .week .day{min-height:0;padding:18px;}
  .page-slug-werken-bij .week .day .d{font-size:24px;}
  .page-slug-werken-bij .week .day h4{font-size:16px;margin-top:12px;}
  .page-slug-werken-bij .week .day p{font-size:12px;}

  /* 04 · academy */
  .page-slug-werken-bij .acad-hero{grid-template-columns:1fr;padding:24px 20px;}
  .page-slug-werken-bij .acad-hero .gr-display{font-size:32px;}
  .page-slug-werken-bij .acad-hero .hero-lead{font-size:14px;margin-top:14px;max-width:none;}
  .page-slug-werken-bij .acad-trail .tfpair{grid-template-columns:1fr;gap:0;}
  .page-slug-werken-bij .acad-trail .tcard{padding:18px;}
  .page-slug-werken-bij .acad-trail .tarrow{flex-direction:row;gap:9px;padding:12px 0;}
  .page-slug-werken-bij .acad-trail .tarrow .big{font-size:18px;}
  .page-slug-werken-bij .acad-trail .tarrow .m{writing-mode:horizontal-tb;transform:none;font-size:9px;}

  /* programs */
  .page-slug-werken-bij .programs{grid-template-columns:1fr;margin-bottom:24px;}
  .page-slug-werken-bij .prog{min-height:0;padding:20px 18px;}
  .page-slug-werken-bij .prog .bn{font-size:26px;}
  .page-slug-werken-bij .prog h4{font-size:18px;}
  .page-slug-werken-bij .prog p{font-size:13px;}

  /* de afspraak (deal): 2-col + 170px sub-grid -> single column */
  .page-slug-werken-bij .deal{grid-template-columns:1fr;margin-bottom:24px;}
  .page-slug-werken-bij .deal-col{padding:20px 18px;}
  .page-slug-werken-bij .deal-h .t{font-size:17px;}
  .page-slug-werken-bij .deal-col li{grid-template-columns:1fr;gap:3px;}
  .page-slug-werken-bij .deal-col .dk{font-size:10.5px;}
  .page-slug-werken-bij .deal-col .dv{font-size:13px;}

  /* startersfuncties: 5-col row -> stacked card */
  .page-slug-werken-bij .starters{border-radius:14px;}
  .page-slug-werken-bij .st-row{display:flex;flex-direction:column;align-items:flex-start;gap:6px;padding:16px;}
  .page-slug-werken-bij .st-t{font-size:16px;}
  .page-slug-werken-bij .st-note{font-size:12px;}
  .page-slug-werken-bij .st-pay{text-align:left;}
  .page-slug-werken-bij .apply-off{text-align:left;}
  .page-slug-werken-bij .st-row .btn.applybtn{align-self:flex-start;justify-content:flex-start;padding:2px 0 0;}

  /* 05 · paden (paths): 4-col -> stacked */
  .page-slug-werken-bij .paths{grid-template-columns:1fr;}
  .page-slug-werken-bij .paths .pth{min-height:0;padding:18px;}
  .page-slug-werken-bij .paths .pth h4{font-size:17px;}
  .page-slug-werken-bij .paths .pth p{font-size:12.5px;}
  .page-slug-werken-bij .paths .pth .role{margin-top:10px;padding-top:0;}

  /* testimonial: 2-col -> stacked */
  .page-slug-werken-bij .testi{grid-template-columns:1fr;gap:24px;}
  .page-slug-werken-bij .testi .quote{font-size:22px;}
  .page-slug-werken-bij .testi-ph{height:240px;}

  /* 06 · open sollicitatie panel: 2-col -> stacked */
  .page-slug-werken-bij .apply-panel{grid-template-columns:1fr;}
  .page-slug-werken-bij .apply-l{padding:24px 20px;}
  .page-slug-werken-bij .apply-l h2{font-size:28px;}
  .page-slug-werken-bij .apply-l .intro{font-size:14px;max-width:none;}
  .page-slug-werken-bij .apply-contact{padding-top:20px;}
  .page-slug-werken-bij .apply-contact .num{font-size:19px;}
  .page-slug-werken-bij .apply-form{padding:24px 20px;}
  .page-slug-werken-bij .apply-form .ff-submit{width:100%;justify-content:center;align-self:auto;}

  /* section CTAs full-width (matches hero/werken mobile pattern) */
  .page-slug-werken-bij .vac-cta{margin-top:24px;}
  .page-slug-werken-bij .vac-cta .btn{width:100%;justify-content:center;}
}
@media (max-width:480px){
  .page-slug-werken-bij .gr-display{font-size:30px;}
  .page-slug-werken-bij .week{grid-template-columns:1fr;}
  .page-slug-werken-bij .evp-idx .er .big{font-size:42px;}
}
/* ===== vacatures overview (.page-slug-vacatures) ===== */
.page-slug-vacatures .block::before{display:none;}
.page-slug-vacatures .vac-headsec{position:relative;}
.page-slug-vacatures .vac-head{max-width:760px;}
.page-slug-vacatures .vac-h1{font-size:54px;line-height:1.0;letter-spacing:-.035em;font-weight:600;margin-top:18px;color:var(--ink);}
.page-slug-vacatures .vac-h1 .ac{color:var(--accent);}
.page-slug-vacatures .vac-intro{font-size:18px;color:var(--ink-2);line-height:1.55;margin-top:20px;max-width:620px;}
.page-slug-vacatures .vac-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:30px;}
.page-slug-vacatures .vchip{font-family:var(--mono);font-size:11px;letter-spacing:.04em;text-transform:uppercase;padding:9px 15px;border-radius:999px;border:1px solid var(--line-2);color:var(--ink-2);background:#fff;cursor:pointer;transition:background .2s ease,color .2s ease,border-color .2s ease;}
.page-slug-vacatures .vchip b{color:var(--accent);font-weight:500;margin-left:2px;}
.page-slug-vacatures .vchip:hover{border-color:var(--ink-3);}
.page-slug-vacatures .vchip.on{background:var(--ink);color:#fff;border-color:var(--ink);}
.page-slug-vacatures .vchip.on b{color:#7fb0ff;}
.page-slug-vacatures .vac-group{margin-bottom:40px;}
.page-slug-vacatures .vac-group.hide{display:none;}
.page-slug-vacatures .vac-glabel{display:flex;align-items:center;gap:10px;margin-bottom:16px;}
.page-slug-vacatures .vac-glabel .dot{width:6px;height:6px;border-radius:50%;background:var(--ink);}
.page-slug-vacatures .vac-glabel .mono{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);white-space:nowrap;}
.page-slug-vacatures .vac-glabel .ct{color:var(--ink-3);}
.page-slug-vacatures .vac-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.page-slug-vacatures .vac-card{display:flex;flex-direction:column;gap:9px;text-decoration:none;color:inherit;background:linear-gradient(165deg,#fafbfc 0%,#eef1f5 100%);border:1px solid var(--line);border-left:3px solid var(--line-2);border-radius:13px;padding:22px 24px;min-height:140px;transition:background .3s ease,border-color .25s ease;}
.page-slug-vacatures .vac-card:hover{background:linear-gradient(165deg,#ffffff 0%,#eef2f7 100%);border-left-color:var(--accent);}
.page-slug-vacatures .vac-card.feat{border-color:rgba(31,95,214,.4);border-left:3px solid var(--accent);background:linear-gradient(165deg,#f3f7ff 0%,#e8eef9 100%);}
.page-slug-vacatures .vac-card .vc-top{display:flex;justify-content:space-between;align-items:baseline;gap:12px;}
.page-slug-vacatures .vac-card .vc-title{font-size:19px;font-weight:600;letter-spacing:-.015em;color:var(--ink);line-height:1.2;}
.page-slug-vacatures .vac-card .vc-loc{font-family:var(--mono);font-size:10px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3);white-space:nowrap;flex:none;}
.page-slug-vacatures .vac-card .vc-meta{font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3);}
.page-slug-vacatures .vac-card .vc-foot{margin-top:auto;padding-top:14px;display:flex;justify-content:space-between;align-items:baseline;gap:10px;}
.page-slug-vacatures .vac-card .vc-pay{font-family:var(--mono);font-size:13px;font-weight:500;color:var(--ink);}
.page-slug-vacatures .vac-card .vc-go{font-family:var(--mono);font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--accent);white-space:nowrap;}
.page-slug-vacatures .vac-card .vc-go .ar{display:inline-block;transition:transform .2s ease;}
.page-slug-vacatures .vac-card:hover .vc-go .ar{transform:translateX(3px);}
.page-slug-vacatures .vac-band{margin-top:8px;border-radius:18px;overflow:hidden;background:radial-gradient(920px 480px at 82% -16%,rgba(28,41,66,1),rgba(14,17,24,1) 72%);color:#fff;padding:40px 44px;display:grid;grid-template-columns:1.4fr auto;gap:40px;align-items:center;box-shadow:0 44px 90px -46px rgba(14,17,24,.7);}
.page-slug-vacatures .vac-band h3{font-size:32px;font-weight:600;letter-spacing:-.025em;color:#fff;}
.page-slug-vacatures .vac-band p{margin-top:12px;font-size:15px;color:#9aa3b2;line-height:1.55;max-width:520px;}
.page-slug-vacatures .vac-band .btn-light{background:#fff;color:var(--ink);white-space:nowrap;}
.page-slug-vacatures .vac-band .btn-light:hover{background:#fff;box-shadow:0 0 0 4px rgba(127,176,255,.22),0 0 20px rgba(127,176,255,.3);}
@media (max-width:768px){
  .page-slug-vacatures .vac-headsec{padding-top:104px !important;}
  .page-slug-vacatures .vac-h1{font-size:34px;margin-top:12px;}
  .page-slug-vacatures .vac-intro{font-size:14px;margin-top:14px;}
  .page-slug-vacatures .vac-filters{gap:7px;margin-bottom:20px;}
  .page-slug-vacatures .vchip{font-size:10px;padding:8px 12px;}
  .page-slug-vacatures .vac-group{margin-bottom:26px;}
  .page-slug-vacatures .vac-grid{grid-template-columns:1fr;gap:10px;}
  .page-slug-vacatures .vac-card{padding:16px 18px;border-radius:12px;min-height:0;}
  .page-slug-vacatures .vac-card .vc-title{font-size:16px;}
  .page-slug-vacatures .vac-card .vc-foot{margin-top:6px;padding-top:10px;border-top:1px solid var(--line);}
  .page-slug-vacatures .vac-band{grid-template-columns:1fr;gap:18px;padding:24px 20px;border-radius:14px;}
  .page-slug-vacatures .vac-band h3{font-size:24px;}
  .page-slug-vacatures .vac-band p{font-size:14px;}
  .page-slug-vacatures .vac-band .btn-light{width:100%;justify-content:center;}
}

/* ===== cases archive (.post-type-archive-fc_case) ===== */
.post-type-archive-fc_case .svc{display:grid;grid-template-columns:repeat(6,1fr);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--paper);}
.post-type-archive-fc_case .tile .chip{position:absolute;top:30px;right:30px;display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);border:1px solid var(--line-2);border-radius:999px;padding:5px 10px;background:var(--paper);}
.post-type-archive-fc_case .tile .chip .d{width:6px;height:6px;border-radius:50%;background:var(--accent);}
.post-type-archive-fc_case .tile .chip.kern{color:var(--ink);}
.post-type-archive-fc_case .tile .chip.kern .d{background:var(--ink);}
.post-type-archive-fc_case .t-ups .frame{position:relative;border:1px solid var(--line);overflow:hidden;min-height:280px;}
.post-type-archive-fc_case .t-ups .frame .anno{top:12px;left:12px;}
.post-type-archive-fc_case .prod .frame{position:relative;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;height:380px;background:var(--paper);}
.post-type-archive-fc_case .prod .frame .anno{top:14px;left:14px;}
.post-type-archive-fc_case .prod .list .ar{color:var(--ink-3);}
.post-type-archive-fc_case .case .frame{position:relative;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;height:240px;background:var(--paper);}
.post-type-archive-fc_case .case .frame .anno{top:12px;left:12px;}
.post-type-archive-fc_case .eod .lbl .d{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 3px rgba(31,95,214,.14);}
.post-type-archive-fc_case .tile:hover .go, .post-type-archive-fc_case .case:hover .go, .post-type-archive-fc_case .prod .list a:hover .ar{color:var(--accent-ink);}
.post-type-archive-fc_case .tile:hover .go .ar, .post-type-archive-fc_case .case:hover .go .ar, .post-type-archive-fc_case .prod .list a:hover .ar{transform:translateX(5px);}
.post-type-archive-fc_case .sp-hero .eyebrow{display:flex;align-items:center;gap:12px;}
.post-type-archive-fc_case .sp-hero .eyebrow .bar{width:26px;height:1px;background:#6b7686;}
.post-type-archive-fc_case .sp-hero .lead{margin-top:24px;font-size:19px;line-height:1.55;color:var(--ink-2);max-width:58ch;}
.post-type-archive-fc_case .sp-hero .jump a .n{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--ink-3);}
.post-type-archive-fc_case .sp-hero .jump a:hover .n{color:var(--accent);}
.post-type-archive-fc_case .sp-card .frame{position:relative;height:204px;overflow:hidden;border-bottom:1px solid var(--line);background:#dcd8cf;}
.post-type-archive-fc_case .sp-grid.cols4 .sp-card .frame{height:158px;}
.post-type-archive-fc_case .sp-card .frame .anno{top:12px;left:12px;}
.post-type-archive-fc_case .sp-card .frame::after{content:"";position:absolute;inset:0;background:linear-gradient(150deg,transparent 46%,rgba(31,95,214,.2));z-index:2;pointer-events:none;}
.post-type-archive-fc_case .sp-card .body{padding:24px 24px 26px;display:flex;flex-direction:column;flex:1;}
.post-type-archive-fc_case .sp-card .chip{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:linear-gradient(120deg,#1f5fd6,#5b7bff);border-radius:999px;padding:4px 9px;}
.post-type-archive-fc_case .sp-card .chip .d{width:6px;height:6px;border-radius:50%;background:#fff;}
.post-type-archive-fc_case .sp-card .chip.kern{background:linear-gradient(120deg,#2b313c,#4c5563);}
.post-type-archive-fc_case .sp-card .chip.soft{background:none;color:var(--ink-3);border:1px solid var(--line-2);}
.post-type-archive-fc_case .sp-card .chip.soft .d{background:var(--ink-3);}
.post-type-archive-fc_case .sp-card .go{margin-top:auto;padding-top:20px;font-size:13px;font-weight:500;color:var(--accent);display:inline-flex;align-items:center;gap:7px;}
.post-type-archive-fc_case .sp-card .go .ar{transition:transform .28s cubic-bezier(.2,.7,.2,1);}
.post-type-archive-fc_case .sp-card:hover .go .ar{transform:translateX(4px);}
.post-type-archive-fc_case .sp-cta{padding:var(--sec-y) 0;}
.post-type-archive-fc_case .sp-cta .card{position:relative;overflow:hidden;display:flex;align-items:center;justify-content:space-between;gap:48px;background:radial-gradient(880px 420px at 84% -28%,rgba(31,95,214,.18),transparent 64%),var(--paper);border:1px solid var(--line);border-radius:22px;padding:52px 56px;box-shadow:0 34px 70px -46px rgba(30,42,64,.55);}
.post-type-archive-fc_case .sp-cta h2{font-size:34px;letter-spacing:-.03em;color:var(--ink);max-width:20ch;margin-top:16px;}
.post-type-archive-fc_case .sp-cta p{margin-top:14px;color:var(--ink-2);font-size:15px;line-height:1.55;max-width:46ch;}
.post-type-archive-fc_case .sp-cta .acts{display:flex;gap:12px;flex-shrink:0;}
.post-type-archive-fc_case .prod .frame{height:472px;}
.post-type-archive-fc_case .svc .tile .tags{margin-top:14px;}
.post-type-archive-fc_case .pc .frame .anno{top:12px;left:12px;}
/* ===== fc-cases-globe-v1 · cases-archive dark EMEA globe hero (replaces .cs-hero) ===== */
.post-type-archive-fc_case .cs-ghero{position:relative;overflow:hidden;height:884px;border-bottom:1px solid rgba(255,255,255,.08);background:radial-gradient(1100px 760px at 60% 34%,#1b2740 0%,#0e1118 74%);}
.post-type-archive-fc_case .cs-ghero .cghero-globe{position:absolute;inset:0;width:100%;height:100%;display:block;z-index:0;}
.post-type-archive-fc_case .cs-ghero .wrap{position:relative;height:100%;z-index:2;}
.post-type-archive-fc_case .cs-ghero .cghero-copy{position:absolute;left:40px;bottom:88px;width:760px;max-width:calc(100% - 80px);}
.post-type-archive-fc_case .cs-ghero .eyebrow{display:flex;align-items:center;gap:12px;}
.post-type-archive-fc_case .cs-ghero .eyebrow .dot{width:7px;height:7px;border-radius:50%;background:#7fb0ff;box-shadow:0 0 0 4px rgba(127,176,255,.18),0 0 10px rgba(127,176,255,.6);}
.post-type-archive-fc_case .cs-ghero .eyebrow .mono{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.65);white-space:nowrap;}
.post-type-archive-fc_case .cs-ghero h1{font-size:72px;line-height:1.0;letter-spacing:-.04em;font-weight:700;color:#fff;max-width:16ch;margin-top:22px;}
.post-type-archive-fc_case .cs-ghero .lead{margin-top:22px;font-size:18px;line-height:1.6;color:rgba(255,255,255,.72);max-width:52ch;}
.post-type-archive-fc_case .m-cs-ghero{display:none;}
@media (max-width:768px){
  .post-type-archive-fc_case .cs-ghero{display:none;}
  .post-type-archive-fc_case .m-cs-ghero{display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden;min-height:100vh;min-height:calc(100lvh + 10vh);padding:96px 20px 24px;padding:96px 20px calc(100lvh + 10vh - var(--fc-vh, 100svh) + 24px);border-bottom:1px solid rgba(255,255,255,.08);background:radial-gradient(520px 620px at 52% 34%,#1b2740 0%,#0e1118 82%);}
  .post-type-archive-fc_case .m-cs-ghero .cghero-globe{position:absolute;inset:0;width:100%;height:100%;display:block;z-index:0;}
  .post-type-archive-fc_case .m-cs-ghero .m-cghero-copy{position:relative;z-index:2;}
  .post-type-archive-fc_case .m-cs-ghero .eyebrow{display:flex;align-items:center;gap:10px;}
  .post-type-archive-fc_case .m-cs-ghero .eyebrow .dot{width:7px;height:7px;border-radius:50%;background:#7fb0ff;box-shadow:0 0 0 3px rgba(127,176,255,.18),0 0 8px rgba(127,176,255,.6);}
  .post-type-archive-fc_case .m-cs-ghero .eyebrow .mono{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.65);}
  .post-type-archive-fc_case .m-cs-ghero h1{font-size:32px;line-height:1.04;letter-spacing:-.035em;font-weight:700;color:#fff;margin-top:14px;}
  .post-type-archive-fc_case .m-cs-ghero .lead{font-size:14px;color:rgba(255,255,255,.72);line-height:1.55;margin-top:13px;}
}
/* ===== /fc-cases-globe-v1 ===== */

/* ===== fc-cases-mobile-v1 · cases-archive mobile DOM (featured case + card grid), display-swapped from desktop ===== */
.post-type-archive-fc_case .m-cs-feat,.post-type-archive-fc_case .m-cs-all{display:none;}
@media (max-width:768px){
  .post-type-archive-fc_case .cs-feat,.post-type-archive-fc_case .cs-all{display:none;}
  .post-type-archive-fc_case .m-cs-feat{display:block;padding:var(--sec-y) 20px;position:relative;isolation:isolate;}
  .post-type-archive-fc_case .m-cs-feat::before{content:"";position:absolute;top:0;left:0;right:0;height:340px;z-index:-1;pointer-events:none;background:none;}
  .post-type-archive-fc_case .m-cs-feat .frame{position:relative;height:200px;border-radius:12px;overflow:hidden;background:#dcd8cf;}
  .post-type-archive-fc_case .m-cs-feat .frame::after{content:"";position:absolute;inset:0;background:linear-gradient(150deg,transparent 46%,rgba(31,95,214,.2));z-index:2;pointer-events:none;}
  .post-type-archive-fc_case .m-cs-feat .badges{display:flex;align-items:center;gap:9px;margin-top:18px;}
  .post-type-archive-fc_case .m-cs-feat .badges .chip{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:linear-gradient(120deg,#1f5fd6,#5b7bff);border-radius:999px;padding:4px 9px;}
  .post-type-archive-fc_case .m-cs-feat .badges .chip .d{width:5px;height:5px;border-radius:50%;background:#fff;}
  .post-type-archive-fc_case .m-cs-feat .badges .mono{font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);}
  .post-type-archive-fc_case .m-cs-feat h2{font-size:24px;letter-spacing:-.03em;margin-top:14px;line-height:1.08;}
  .post-type-archive-fc_case .m-cs-feat .who{font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);margin-top:10px;}
  .post-type-archive-fc_case .m-cs-feat p{font-size:13.5px;color:var(--ink-2);line-height:1.55;margin-top:12px;}
  .post-type-archive-fc_case .m-cs-feat .stats{display:grid;grid-template-columns:repeat(3,1fr);border:1px solid var(--line);border-radius:11px;overflow:hidden;margin-top:18px;}
  .post-type-archive-fc_case .m-cs-feat .stats .s{padding:13px 12px;border-left:1px solid var(--line);}
  .post-type-archive-fc_case .m-cs-feat .stats .s:first-child{border-left:0;}
  .post-type-archive-fc_case .m-cs-feat .stats .s .n{font-size:21px;letter-spacing:-.02em;}
  .post-type-archive-fc_case .m-cs-feat .stats .s .l{font-family:var(--mono);font-size:9px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3);margin-top:4px;}
  .post-type-archive-fc_case .m-cs-feat .go{margin-top:18px;font-size:13px;font-weight:500;color:var(--accent);display:inline-flex;align-items:center;gap:7px;}
  .post-type-archive-fc_case .m-cs-all{display:block;padding:var(--sec-y) 20px;position:relative;isolation:isolate;}
  .post-type-archive-fc_case .m-cs-all::before{content:"";position:absolute;top:0;left:0;right:0;height:340px;z-index:-1;pointer-events:none;background:none;}
  /* compact horizontal cards + scrollable filter pills with counts (fc-cases-compact-v1) */
  .post-type-archive-fc_case .m-cs-filters{display:flex;gap:7px;overflow-x:auto;margin:14px -20px 18px;padding:0 20px 4px;scrollbar-width:none;}
  .post-type-archive-fc_case .m-cs-filters::-webkit-scrollbar{display:none;}
  .post-type-archive-fc_case .m-cs-filters button{flex:none;display:inline-flex;align-items:center;gap:7px;padding:8px 13px;cursor:pointer;font-family:var(--mono);font-size:10px;letter-spacing:.04em;text-transform:uppercase;border:1px solid var(--line-2);background:var(--paper);border-radius:999px;color:var(--ink-2);white-space:nowrap;}
  .post-type-archive-fc_case .m-cs-filters button .ct{color:var(--ink-3);}
  .post-type-archive-fc_case .m-cs-filters button.on{background:var(--ink);border-color:var(--ink);color:#fff;}
  .post-type-archive-fc_case .m-cs-filters button.on .ct{color:rgba(255,255,255,.6);}
  .post-type-archive-fc_case .m-cs-grid{display:flex;flex-direction:column;gap:11px;}
  .post-type-archive-fc_case .m-cs-card{display:grid;grid-template-columns:78px 1fr;gap:13px;align-items:center;padding:11px;border:1px solid var(--line);border-radius:13px;background:var(--paper);text-decoration:none;color:inherit;}
  .post-type-archive-fc_case .m-cs-card .thumb{width:78px;height:78px;border-radius:9px;position:relative;overflow:hidden;background:#cdd1d6;}
  .post-type-archive-fc_case .m-cs-card .thumb .img-slot--todo{position:absolute;inset:0;width:100%;height:100%;}
  .post-type-archive-fc_case .m-cs-card .b{min-width:0;}
  .post-type-archive-fc_case .m-cs-card .who{font-family:var(--mono);font-size:9.5px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3);}
  .post-type-archive-fc_case .m-cs-card h4{font-size:14.5px;font-weight:500;letter-spacing:-.01em;margin-top:4px;line-height:1.25;}
  .post-type-archive-fc_case .m-cs-card .yr{margin-top:6px;font-family:var(--mono);font-size:9.5px;color:var(--ink-3);}
  .post-type-archive-fc_case .m-cs-card[hidden]{display:none;}
}
/* ===== /fc-cases-mobile-v1 ===== */

.post-type-archive-fc_case .cs-hero{position:relative;padding:140px 0 var(--sec-y);isolation:isolate;}
.post-type-archive-fc_case .cs-hero::before{content:"";position:absolute;top:0;left:0;right:0;height:520px;z-index:-1;pointer-events:none;background:none;}
.post-type-archive-fc_case .cs-hero .row{display:block;}
.post-type-archive-fc_case .cs-hero .eyebrow{display:flex;align-items:center;gap:12px;margin-bottom:24px;}
.post-type-archive-fc_case .cs-hero .eyebrow .bar{width:26px;height:1px;background:#6b7686;}
.post-type-archive-fc_case .cs-hero .eyebrow .mono{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);;white-space:nowrap;}
.post-type-archive-fc_case .cs-hero h1{font-size:62px;line-height:1.02;letter-spacing:-.045em;max-width:17ch;}
.post-type-archive-fc_case .cs-hero .lead{margin-top:24px;font-size:18px;line-height:1.6;color:var(--ink-2);max-width:58ch;}
.post-type-archive-fc_case .cs-hero .meta{border-left:1px solid var(--line);padding-left:24px;display:flex;flex-direction:column;gap:20px;}
.post-type-archive-fc_case .cs-hero .meta .k{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);}
.post-type-archive-fc_case .cs-hero .meta .v{font-size:14px;color:var(--ink);margin-top:4px;}
.post-type-archive-fc_case .cs-feat{padding:var(--sec-y) 0;position:relative;isolation:isolate;}
.post-type-archive-fc_case .cs-feat::before{content:"";position:absolute;top:0;left:0;right:0;height:560px;z-index:-1;pointer-events:none;background:none;}
.post-type-archive-fc_case .cs-feat .in{display:grid;grid-template-columns:1.15fr 1fr;gap:56px;align-items:stretch;}
.post-type-archive-fc_case .cs-feat .frame{position:relative;border:1px solid var(--line);border-radius:16px;overflow:hidden;background:#dcd8cf;min-height:440px;box-shadow:0 30px 64px -42px rgba(20,25,40,.5);}
.post-type-archive-fc_case .cs-feat .frame .anno{top:14px;left:14px;}
.post-type-archive-fc_case .cs-feat .frame::after{content:"";position:absolute;inset:0;background:linear-gradient(150deg,transparent 50%,rgba(31,95,214,.2));z-index:2;pointer-events:none;}
.post-type-archive-fc_case .cs-feat .tx{display:flex;flex-direction:column;justify-content:flex-start;}
.post-type-archive-fc_case .cs-feat .badges{display:flex;align-items:center;gap:10px;margin-bottom:16px;}
.post-type-archive-fc_case .cs-feat .badges .chip{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:linear-gradient(120deg,#1f5fd6,#5b7bff);border-radius:999px;padding:5px 11px;}
.post-type-archive-fc_case .cs-feat .badges .chip .d{width:6px;height:6px;border-radius:50%;background:#fff;}
.post-type-archive-fc_case .cs-feat .badges .mono{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);}
.post-type-archive-fc_case .cs-feat h2{font-size:38px;letter-spacing:-.03em;line-height:1.05;}
.post-type-archive-fc_case .cs-feat .who{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);margin-top:12px;}
.post-type-archive-fc_case .cs-feat p{margin-top:14px;font-size:16px;color:var(--ink-2);line-height:1.6;max-width:50ch;}
.post-type-archive-fc_case .cs-feat .stats{display:grid;grid-template-columns:repeat(3,1fr);border:1px solid var(--line);border-radius:12px;overflow:hidden;margin-top:30px;}
.post-type-archive-fc_case .cs-feat .stats .s{padding:18px 20px;border-left:1px solid var(--line);}
.post-type-archive-fc_case .cs-feat .stats .s:first-child{border-left:0;}
.post-type-archive-fc_case .cs-feat .stats .s .n{font-size:28px;letter-spacing:-.02em;}
.post-type-archive-fc_case .cs-feat .stats .s .l{font-family:var(--mono);font-size:10px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3);margin-top:5px;}
.post-type-archive-fc_case .cs-feat .go{margin-top:auto;align-self:flex-start;}
.post-type-archive-fc_case .cs-all{padding:var(--sec-y) 0;position:relative;isolation:isolate;}
.post-type-archive-fc_case .cs-all::before{content:"";position:absolute;top:0;left:0;right:0;height:560px;z-index:-1;pointer-events:none;background:none;}
.post-type-archive-fc_case .cs-all .cs-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:28px;}
.post-type-archive-fc_case .cs-filters{display:flex;flex-wrap:wrap;gap:8px;}
.post-type-archive-fc_case .cs-filters button{padding:8px 14px;cursor:pointer;font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;border:1px solid var(--line-2);background:var(--paper);color:var(--ink-2);border-radius:999px;transition:background .15s,color .15s,border-color .15s;}
.post-type-archive-fc_case .cs-filters button:hover{border-color:var(--accent);color:var(--accent);}
.post-type-archive-fc_case .cs-filters button.on{background:var(--ink);border-color:var(--ink);color:#fff;}
.cs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.cs-card{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--paper);text-decoration:none;color:inherit;box-shadow:0 14px 30px -26px rgba(30,42,64,.5);transition:box-shadow .3s ease,transform .3s ease;}
.cs-card:hover{box-shadow:0 30px 60px -34px rgba(30,42,64,.55);transform:translateY(-3px);}
.cs-card .frame{position:relative;height:176px;overflow:hidden;border-bottom:1px solid var(--line);background:#dcd8cf;}
.cs-card .frame .anno{top:12px;left:12px;}
.cs-card .frame::after{content:"";position:absolute;inset:0;background:linear-gradient(150deg,transparent 50%,rgba(31,95,214,.18));z-index:2;pointer-events:none;}
.cs-card .body{padding:20px 22px 22px;display:flex;flex-direction:column;flex:1;}
.cs-card .who{font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);}
.cs-card h4{font-size:19px;font-weight:500;letter-spacing:-.015em;line-height:1.22;margin-top:9px;}
.cs-card p{font-size:13.5px;color:var(--ink-2);line-height:1.5;margin-top:10px;}
.cs-card .ft{margin-top:auto;padding-top:16px;display:flex;align-items:center;justify-content:space-between;gap:10px;}
.cs-card .ft .svc-tag{white-space:nowrap;font-family:var(--mono);font-size:9.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-2);}
.cs-card .ft .yr{font-family:var(--mono);font-size:10px;letter-spacing:.04em;color:var(--ink-3);}
.cs-card[hidden]{display:none;}
/* ===== case single (.single-fc_case) ===== */
.single-fc_case .tile .chip{position:absolute;top:30px;right:30px;display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);border:1px solid var(--line-2);border-radius:999px;padding:5px 10px;background:var(--paper);}
.single-fc_case .tile .chip .d{width:6px;height:6px;border-radius:50%;background:var(--accent);}
.single-fc_case .tile .chip.kern{color:var(--ink);}
.single-fc_case .tile .chip.kern .d{background:var(--ink);}
.single-fc_case .t-ups .frame{position:relative;border:1px solid var(--line);overflow:hidden;min-height:280px;}
.single-fc_case .t-ups .frame .anno{top:12px;left:12px;}
.single-fc_case .prod .frame{position:relative;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;height:380px;background:var(--paper);}
.single-fc_case .prod .frame .anno{top:14px;left:14px;}
.single-fc_case .prod .list{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--paper);}
.single-fc_case .prod .list a{display:grid;grid-template-columns:170px 1fr 20px;gap:16px;padding:16px 18px;border-top:1px solid var(--line);align-items:center;}
.single-fc_case .prod .list .ar{color:var(--ink-3);}
.single-fc_case .case .frame{position:relative;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;height:240px;background:var(--paper);}
.single-fc_case .case .frame .anno{top:12px;left:12px;}
.single-fc_case .case .meta{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);margin-top:16px;}
.single-fc_case .tile:hover .go, .single-fc_case .case:hover .go, .single-fc_case .prod .list a:hover .ar{color:var(--accent-ink);}
.single-fc_case .tile:hover .go .ar, .single-fc_case .case:hover .go .ar, .single-fc_case .prod .list a:hover .ar{transform:translateX(5px);}
.single-fc_case .eod h3, .single-fc_case .eod .phone{color:#fff;}
.single-fc_case .sp-hero .eyebrow{display:flex;align-items:center;gap:12px;}
.single-fc_case .sp-hero .eyebrow .bar{width:26px;height:1px;background:#6b7686;}
.single-fc_case .sp-hero .lead{margin-top:24px;font-size:19px;line-height:1.55;color:var(--ink-2);max-width:58ch;}
.single-fc_case .sp-hero .jump a .n{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--ink-3);}
.single-fc_case .sp-hero .jump a:hover .n{color:var(--accent);}
.single-fc_case .sp-sec .lhs{display:flex;flex-direction:column;gap:0;max-width:60ch;}
.single-fc_case .sp-sec .intro{color:var(--ink-2);font-size:16px;line-height:1.6;}
.single-fc_case .sp-card .frame{position:relative;height:204px;overflow:hidden;border-bottom:1px solid var(--line);background:#dcd8cf;}
.single-fc_case .sp-grid.cols4 .sp-card .frame{height:158px;}
.single-fc_case .sp-card .frame .anno{top:12px;left:12px;}
.single-fc_case .sp-card .frame::after{content:"";position:absolute;inset:0;background:linear-gradient(150deg,transparent 46%,rgba(31,95,214,.2));z-index:2;pointer-events:none;}
.single-fc_case .sp-card .chip{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:linear-gradient(120deg,#1f5fd6,#5b7bff);border-radius:999px;padding:4px 9px;}
.single-fc_case .sp-card .chip .d{width:6px;height:6px;border-radius:50%;background:#fff;}
.single-fc_case .sp-card .chip.kern{background:linear-gradient(120deg,#2b313c,#4c5563);}
.single-fc_case .sp-card .chip.soft{background:none;color:var(--ink-3);border:1px solid var(--line-2);}
.single-fc_case .sp-card .chip.soft .d{background:var(--ink-3);}
.single-fc_case .sp-card .go{margin-top:auto;padding-top:20px;font-size:13px;font-weight:500;color:var(--accent);display:inline-flex;align-items:center;gap:7px;}
.single-fc_case .sp-card .go .ar{transition:transform .28s cubic-bezier(.2,.7,.2,1);}
.single-fc_case .sp-card:hover .go .ar{transform:translateX(4px);}
.single-fc_case .sp-cta .in{display:flex;align-items:center;justify-content:space-between;gap:48px;}
.single-fc_case .sp-cta .secnum .bar{background:rgba(255,255,255,.4);}
.single-fc_case .sp-cta .secnum .mono{color:rgba(255,255,255,.55);}
.single-fc_case .sp-cta .acts{display:flex;gap:12px;flex-shrink:0;}
.single-fc_case .sp-cta .btn-ghost{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.28);}
.single-fc_case .sp-cta .btn-ghost:hover{color:#cfe0ff;border-color:#7fb0ff;box-shadow:0 0 0 4px rgba(127,176,255,.2);}
.single-fc_case .prod .frame{height:472px;}
.single-fc_case .prod .list .rowtext{display:flex;flex-direction:column;gap:5px;min-width:0;}
.single-fc_case .prod .list .rowtext .spec{font-family:var(--mono);font-size:10px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-3);}
.single-fc_case .prod .list a{grid-template-columns:180px 1fr 20px;padding:22px 24px;}
.single-fc_case .pc .frame .anno{top:12px;left:12px;}
.single-fc_case .svc-hero{position:relative;padding:140px 0 var(--sec-y);}
.single-fc_case .svc-hero .row{display:grid;grid-template-columns:1fr 360px;gap:64px;align-items:flex-end;}
.single-fc_case .svc-hero .badges{display:flex;align-items:center;gap:12px;margin-bottom:24px;}
.single-fc_case .svc-hero .ix{font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--ink-3);}
.single-fc_case .svc-hero .chip{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:linear-gradient(120deg,#2b313c,#4c5563);border-radius:999px;padding:5px 11px;}
.single-fc_case .svc-hero .chip .d{width:6px;height:6px;border-radius:50%;background:#fff;}
.single-fc_case .svc-hero .ey{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);}
.single-fc_case .svc-hero h1{font-size:66px;line-height:1.0;letter-spacing:-.045em;max-width:16ch;}
.single-fc_case .svc-hero .lead{margin-top:26px;font-size:18px;line-height:1.55;color:var(--ink-2);max-width:62ch;}
.single-fc_case .svc-hero .acts{display:flex;flex-wrap:wrap;gap:12px;margin-top:34px;}
.single-fc_case .svc-hero .meta{border-left:1px solid var(--line-2);padding-left:26px;display:flex;flex-direction:column;gap:22px;}
.single-fc_case .svc-hero .meta .k{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);}
.single-fc_case .svc-hero .meta .v{font-size:14px;margin-top:5px;color:var(--ink);line-height:1.45;}
.single-fc_case .svc-heroimg{position:relative;height:468px;background:#dcd8cf;border-bottom:1px solid var(--line);overflow:hidden;}
.single-fc_case .svc-heroimg .anno{top:16px;left:16px;}
.single-fc_case .svc-heroimg::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(31,95,214,.16),transparent 50%);z-index:2;pointer-events:none;}
.single-fc_case .svc-sec{padding:var(--sec-y) 0;position:relative;isolation:isolate;}
.single-fc_case .svc-sec::before, .single-fc_case .blocks::before{content:"";position:absolute;top:0;left:0;right:0;height:560px;z-index:-1;pointer-events:none;}
.single-fc_case .blocks{position:relative;isolation:isolate;}
.single-fc_case .svc-sec.tight{padding:var(--sec-y) 0;}
.single-fc_case .blocks{padding:var(--sec-y) 40px;}
.single-fc_case .cb{display:grid;gap:56px;align-items:stretch;max-width:1360px;margin-left:auto;margin-right:auto;} /* align with .wrap content (1440 - 2x40 padding) so the blocks aren't wider than other sections */
.single-fc_case .cb + .cb{margin-top:64px;}
.single-fc_case .cb.normal{grid-template-columns:1.05fr 1fr;}
.single-fc_case .cb.flip{grid-template-columns:1fr 1.05fr;}
.single-fc_case .cb .txt{align-self:center;}
.single-fc_case .cb .dlab{display:inline-flex;align-items:center;gap:9px;white-space:nowrap;font-family:var(--mono);font-size:13px;font-weight:600;letter-spacing:.02em;margin-bottom:var(--eyb-gap);}
.single-fc_case .cb .dlab .s{color:var(--accent);}
.single-fc_case .cb .dlab .l{color:var(--ink);text-transform:lowercase;letter-spacing:.04em;}
.single-fc_case .cb h3{font-size:30px;font-weight:500;letter-spacing:-.02em;line-height:1.1;margin:20px 0 14px;max-width:18ch;}
.single-fc_case .cb p{font-size:15px;color:var(--ink-2);line-height:1.65;max-width:48ch;}
.single-fc_case .cb .pts{margin-top:24px;border-top:1px solid var(--line);}
.single-fc_case .cb .pts .pt{display:grid;grid-template-columns:24px 1fr;gap:12px;padding:13px 0;border-bottom:1px solid var(--line);align-items:baseline;}
.single-fc_case .cb .pts .pt .pn{font-family:var(--mono);font-size:11px;color:var(--accent);}
.single-fc_case .cb .pts .pt .pv{font-size:14.5px;color:var(--ink);}
.single-fc_case .cb .img{position:relative;min-height:392px;background:#dcd8cf;overflow:hidden;border:1px solid var(--line);}
.single-fc_case .cb .img .anno{top:14px;left:14px;}
.single-fc_case .cb .img .reg{bottom:14px;right:14px;}
.single-fc_case .cb .img::after{content:"";position:absolute;inset:0;background:linear-gradient(140deg,transparent 52%,rgba(31,95,214,.16));z-index:2;pointer-events:none;}
.single-fc_case .scope .intro{color:var(--ink-2);font-size:15px;line-height:1.6;max-width:40ch;}
.single-fc_case .scope summary .k{font-family:var(--mono);font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink);}
.single-fc_case .scope summary .v{font-size:14px;color:var(--ink-2);}
.single-fc_case .svc-ov{padding:var(--sec-y) 0;position:relative;isolation:isolate;}
.single-fc_case .svc-ov::before{content:"";position:absolute;top:0;left:0;right:0;height:560px;z-index:-1;pointer-events:none;}
.single-fc_case .svc-ov .ov-h{font-size:46px;letter-spacing:-.04em;line-height:1.04;max-width:24ch;}
.single-fc_case .svc-ov .ov-h em{font-style:normal;color:var(--accent);}
.single-fc_case .svc-ov .ov-row{display:grid;grid-template-columns:1fr 320px;gap:60px;margin-top:32px;align-items:start;} /* fc-case-globe-v1: facts moved here from hero */
.single-fc_case .svc-ov .ov-row .lead{margin-top:0;}
.single-fc_case .svc-ov .ov-facts{display:grid;grid-template-columns:1fr 1fr;gap:1px;margin-top:0;background:var(--line);border:1px solid var(--line);border-radius:12px;overflow:hidden;}
.single-fc_case .svc-ov .ov-facts > div{background:var(--bg-2);padding:16px 18px;}
.single-fc_case .svc-ov .ov-facts .k{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);}
.single-fc_case .svc-ov .ov-facts .v{font-size:15px;color:var(--ink);margin-top:6px;font-weight:500;}
.single-fc_case .svc-ov .ov-facts .v.cls{color:var(--accent);}
.single-fc_case .svc-ov .lead{display:flex;flex-direction:column;gap:18px;max-width:68ch;}
.single-fc_case .svc-ov .lead p{font-size:17px;line-height:1.72;color:var(--ink-2);}
.single-fc_case .svc-ov .lead p b{color:var(--ink);font-weight:500;}
.single-fc_case .svc-ov .ov-stats{border-top:1px solid var(--ink);}
.single-fc_case .svc-ov .ov-stats .s{display:flex;align-items:baseline;justify-content:space-between;gap:20px;padding:15px 0;border-bottom:1px solid var(--line);}
.single-fc_case .svc-ov .ov-stats .k{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);}
.single-fc_case .svc-ov .ov-stats .v{font-size:14px;color:var(--ink);text-align:right;letter-spacing:-.01em;}
.single-fc_case .svc-ov .wp-head{display:flex;align-items:baseline;justify-content:space-between;margin-top:58px;padding-bottom:13px;}
.single-fc_case .svc-ov .wp-head .t{font-size:24px;font-weight:600;letter-spacing:-.02em;}
.single-fc_case .svc-ov .wp-head .c{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--ink-3);}
.single-fc_case .md input{position:absolute;opacity:0;pointer-events:none;}
.single-fc_case .md .cols{display:grid;grid-template-columns:0.9fr 1.1fr;margin-top:22px;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--paper);box-shadow:0 24px 54px -42px rgba(30,42,64,.5);}
.single-fc_case .md .list{border-right:1px solid var(--line);}
.single-fc_case .md .list label{display:grid;grid-template-columns:34px 1fr 18px;gap:14px;align-items:center;padding:18px 22px;cursor:pointer;border-bottom:1px solid var(--line);transition:background .18s;}
.single-fc_case .md .list label:last-of-type{border-bottom:0;}
.single-fc_case .md .list label .n{font-family:var(--mono);font-size:11px;color:var(--ink-3);}
.single-fc_case .md .list label .t{font-size:17px;letter-spacing:-.01em;color:var(--ink-2);}
.single-fc_case .md .list label .ar{justify-self:end;color:var(--ink-3);opacity:0;transition:opacity .18s;font-family:var(--mono);}
.single-fc_case .md .list label:hover{background:var(--bg-2);}
.single-fc_case .md .detail{padding:34px 34px;background:linear-gradient(180deg,#fbfcfd,#fff);}
.single-fc_case .md .pane{display:none;}
.single-fc_case .md .pane .pn{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--accent);}
.single-fc_case .md .pane h4{font-size:28px;letter-spacing:-.02em;margin-top:12px;}
.single-fc_case .md .pane p{font-size:15px;line-height:1.7;color:var(--ink-2);margin-top:14px;max-width:52ch;}
.single-fc_case .md #u1:checked~.cols .list label[for="u1"], .single-fc_case .md #u2:checked~.cols .list label[for="u2"], .single-fc_case .md #u3:checked~.cols .list label[for="u3"], .single-fc_case .md #u4:checked~.cols .list label[for="u4"], .single-fc_case .md #u5:checked~.cols .list label[for="u5"], .single-fc_case .md #u6:checked~.cols .list label[for="u6"], .single-fc_case .md #u7:checked~.cols .list label[for="u7"]{background:var(--ink);}
.single-fc_case .md #u1:checked~.cols .list label[for="u1"] .t, .single-fc_case .md #u1:checked~.cols .list label[for="u1"] .n, .single-fc_case .md #u1:checked~.cols .list label[for="u1"] .ar, .single-fc_case .md #u2:checked~.cols .list label[for="u2"] .t, .single-fc_case .md #u2:checked~.cols .list label[for="u2"] .n, .single-fc_case .md #u2:checked~.cols .list label[for="u2"] .ar, .single-fc_case .md #u3:checked~.cols .list label[for="u3"] .t, .single-fc_case .md #u3:checked~.cols .list label[for="u3"] .n, .single-fc_case .md #u3:checked~.cols .list label[for="u3"] .ar, .single-fc_case .md #u4:checked~.cols .list label[for="u4"] .t, .single-fc_case .md #u4:checked~.cols .list label[for="u4"] .n, .single-fc_case .md #u4:checked~.cols .list label[for="u4"] .ar, .single-fc_case .md #u5:checked~.cols .list label[for="u5"] .t, .single-fc_case .md #u5:checked~.cols .list label[for="u5"] .n, .single-fc_case .md #u5:checked~.cols .list label[for="u5"] .ar, .single-fc_case .md #u6:checked~.cols .list label[for="u6"] .t, .single-fc_case .md #u6:checked~.cols .list label[for="u6"] .n, .single-fc_case .md #u6:checked~.cols .list label[for="u6"] .ar, .single-fc_case .md #u7:checked~.cols .list label[for="u7"] .t, .single-fc_case .md #u7:checked~.cols .list label[for="u7"] .n, .single-fc_case .md #u7:checked~.cols .list label[for="u7"] .ar{color:#fff;opacity:1;}
.single-fc_case .md #u1:checked~.cols .detail .pane[data-i="1"], .single-fc_case .md #u2:checked~.cols .detail .pane[data-i="2"], .single-fc_case .md #u3:checked~.cols .detail .pane[data-i="3"], .single-fc_case .md #u4:checked~.cols .detail .pane[data-i="4"], .single-fc_case .md #u5:checked~.cols .detail .pane[data-i="5"], .single-fc_case .md #u6:checked~.cols .detail .pane[data-i="6"], .single-fc_case .md #u7:checked~.cols .detail .pane[data-i="7"]{display:block;}
/* fallback: first pane always visible on load so the right column is never empty; hidden once another tab is chosen */
.single-fc_case .md .detail .pane[data-i="1"]{display:block;}
.single-fc_case .md #u2:checked~.cols .detail .pane[data-i="1"], .single-fc_case .md #u3:checked~.cols .detail .pane[data-i="1"], .single-fc_case .md #u4:checked~.cols .detail .pane[data-i="1"], .single-fc_case .md #u5:checked~.cols .detail .pane[data-i="1"], .single-fc_case .md #u6:checked~.cols .detail .pane[data-i="1"], .single-fc_case .md #u7:checked~.cols .detail .pane[data-i="1"]{display:none;}
.single-fc_case .appr-head{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;margin-bottom:40px;}
.single-fc_case .appr-head .lhs{display:flex;flex-direction:column;gap:0;max-width:60ch;}
.single-fc_case .appr-head h2{font-size:38px;letter-spacing:-.03em;max-width:18ch;line-height:1.05;margin-top:2px;}
.single-fc_case .appr-head .intro{font-size:15px;color:var(--ink-2);line-height:1.6;max-width:52ch;}
.single-fc_case .appr .c{padding:26px 22px 24px;background:linear-gradient(165deg,#fafbfc 0%,#ebedf0 100%);display:flex;flex-direction:column;gap:0;min-height:auto;border-left:0;transition:background .3s ease;}
.single-fc_case .appr .c:hover{background:linear-gradient(165deg,#ffffff 0%,#eef2f7 100%);}
.single-fc_case .appr .c .n{font-family:var(--mono);font-size:30px;font-weight:500;letter-spacing:-.03em;color:var(--line-2);line-height:1;}
.single-fc_case .appr .c h4{margin-top:16px;font-size:18px;font-weight:500;letter-spacing:-.015em;line-height:1.2;}
.single-fc_case .appr .c p{margin-top:8px;font-size:13.5px;color:var(--ink-2);line-height:1.6;}
.single-fc_case .cases-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:30px;}
.single-fc_case .ccard .frame{position:relative;height:236px;background:#dcd8cf;overflow:hidden;border-bottom:1px solid var(--line);}
.single-fc_case .ccard .frame .anno{top:12px;left:12px;}
.single-fc_case .ccard .frame::after{content:"";position:absolute;inset:0;background:linear-gradient(150deg,transparent 46%,rgba(31,95,214,.2));z-index:2;pointer-events:none;}
.single-fc_case .ccard .meta{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);}
.single-fc_case .svc-cta{padding:var(--sec-y) 0;}
.single-fc_case .svc-cta .in{display:flex;align-items:center;justify-content:space-between;gap:48px;flex-wrap:wrap;background:radial-gradient(880px 430px at 84% -30%,rgba(31,95,214,.16),transparent 64%),var(--paper);border:1px solid var(--line);border-radius:22px;padding:48px 52px;box-shadow:0 34px 70px -46px rgba(30,42,64,.55);}
.single-fc_case .svc-cta .chip{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-ink);border:1px solid rgba(31,95,214,.3);background:rgba(31,95,214,.06);border-radius:999px;padding:5px 11px;}
.single-fc_case .svc-cta .chip .pulse{width:7px;height:7px;border-radius:50%;background:#22c07a;box-shadow:0 0 0 0 rgba(34,192,122,.6);animation:cpulse 2s infinite;}
.single-fc_case .svc-cta h2{font-size:44px;font-weight:500;letter-spacing:-.025em;line-height:1.05;margin:16px 0 12px;color:var(--ink);max-width:18ch;}
.single-fc_case .svc-cta p{color:var(--ink-2);font-size:16px;line-height:1.55;max-width:46ch;}
.single-fc_case .svc-cta .side{display:flex;flex-direction:column;gap:14px;min-width:230px;}
.single-fc_case .svc-cta .phone{font-family:var(--mono);font-size:24px;font-weight:500;color:var(--ink);}
.single-fc_case .other a .go{margin-top:auto;padding-top:18px;font-size:13px;font-weight:500;color:var(--accent);display:flex;align-items:center;gap:7px;}
.single-fc_case .other a .go .ar{display:inline-block;transition:transform .28s cubic-bezier(.2,.7,.2,1);}
.single-fc_case .other a:hover .go .ar{transform:translateX(5px);}
.single-fc_case .other a .chip{position:absolute;top:26px;right:24px;display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:linear-gradient(120deg,#1f5fd6,#5b7bff);border-radius:999px;padding:4px 9px;}
.single-fc_case .other a .chip .d{width:6px;height:6px;border-radius:50%;background:#fff;}
.single-fc_case .other a .chip.kern{background:linear-gradient(120deg,#2b313c,#4c5563);}
.single-fc_case .prodstrip .chip.kern{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:linear-gradient(120deg,#2b313c,#4c5563);border-radius:999px;padding:4px 9px;}
.single-fc_case .prodstrip .chip.kern .d{width:6px;height:6px;border-radius:50%;background:#fff;}
.single-fc_case .prodstrip .go{font-size:13px;font-weight:500;color:var(--accent);display:inline-flex;align-items:center;gap:7px;}
.single-fc_case .prodstrip .go .ar{display:inline-block;transition:transform .28s cubic-bezier(.2,.7,.2,1);}
.single-fc_case .prodstrip:hover .go .ar{transform:translateX(5px);}
.single-fc_case .case-stats .s .n{font-size:42px;letter-spacing:-.03em;line-height:1;}
.single-fc_case .case-stats .s .l{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);}
.single-fc_case .case-quote{padding:var(--sec-y) 0;position:relative;isolation:isolate;}
.single-fc_case .case-quote::before{content:"";position:absolute;top:0;left:0;right:0;height:560px;z-index:-1;pointer-events:none;background:none;}
.single-fc_case .case-quote blockquote{margin:0;max-width:24ch;}
.single-fc_case .case-quote .q{font-size:40px;line-height:1.18;letter-spacing:-.03em;color:var(--ink);max-width:22ch;}
.single-fc_case .case-quote .q::before{content:"\201C";color:var(--accent);}
.single-fc_case .case-quote .q::after{content:"\201D";color:var(--accent);}
.single-fc_case .case-quote .attr{margin-top:26px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);display:flex;align-items:center;gap:12px;}
.single-fc_case .case-quote .attr .bar{width:26px;height:1px;background:#6b7686;}
.single-fc_case .case-rel{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.single-fc_case .case-rel a{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--paper);text-decoration:none;color:inherit;box-shadow:0 14px 30px -26px rgba(30,42,64,.5);transition:box-shadow .3s ease,transform .3s ease;}
.single-fc_case .case-rel a:hover{box-shadow:0 28px 54px -34px rgba(30,42,64,.55);transform:translateY(-3px);}
.single-fc_case .case-rel .frame{position:relative;height:150px;background:#dcd8cf;border-bottom:1px solid var(--line);overflow:hidden;}
.single-fc_case .case-rel .frame .anno{top:12px;left:12px;}
.single-fc_case .case-rel .bd{padding:20px 22px 22px;display:flex;flex-direction:column;flex:1;}
.single-fc_case .case-rel .meta{font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);}
.single-fc_case .case-rel h4{font-size:18px;letter-spacing:-.02em;margin-top:9px;}
.single-fc_case .case-rel .go{margin-top:auto;padding-top:16px;font-size:13px;font-weight:500;color:var(--accent);display:inline-flex;align-items:center;gap:7px;}
.single-fc_case .svc-cta .svclink{margin-top:14px;font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;}
.single-fc_case .svc-cta .svclink a{color:var(--accent);}
.single-fc_case .case-flow{position:relative;display:grid;grid-template-columns:repeat(var(--flow-cols,4),1fr);gap:clamp(20px,2.2vw,32px);margin-top:8px;}
.single-fc_case .case-flow::before{content:"";position:absolute;top:16px;left:18px;right:calc((100% - (var(--flow-cols,4) - 1) * clamp(20px,2.2vw,32px)) / var(--flow-cols,4) - 17px);height:2px;background:linear-gradient(90deg,rgba(31,95,214,.5),rgba(31,95,214,.18));z-index:0;}
.single-fc_case .case-flow .st{position:relative;z-index:1;padding-top:52px;}
.single-fc_case .case-flow .st .node{position:absolute;top:0;left:0;width:34px;height:34px;border-radius:50%;background:var(--accent);color:#fff;font-family:var(--mono);font-size:12px;font-weight:500;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 0 0 5px var(--bg),0 6px 16px -6px rgba(31,95,214,.6);}
.single-fc_case .case-flow .st .wk{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);}
.single-fc_case .case-flow .st h4{font-size:19px;letter-spacing:-.02em;margin-top:8px;}
.single-fc_case .case-flow .st p{font-size:14px;color:var(--ink-2);line-height:1.55;margin-top:9px;}
.single-fc_case .vd-quote-card{position:relative;background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:46px 50px 40px;box-shadow:0 28px 60px -44px rgba(30,42,64,.5);}
.single-fc_case .vd-q-mark{position:absolute;top:18px;left:36px;font-size:90px;line-height:1;color:rgba(31,95,214,.16);font-family:var(--sans);font-weight:700;}
.single-fc_case .vd-quote{font-size:30px;line-height:1.36;letter-spacing:-.025em;max-width:42ch;color:var(--ink);position:relative;margin:0;}
.single-fc_case .vd-quote-a{margin-top:24px;font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);}
.single-fc_case .svc-hero .eyebrow{display:flex;align-items:center;gap:12px;margin-bottom:24px;}
.single-fc_case .svc-hero .eyebrow .bar{width:26px;height:1px;background:#6b7686;}
.single-fc_case .svc-hero .eyebrow .mono{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);;white-space:nowrap;}
/* ===== fc-case-globe-v1 · case-detail globe hero (definitive; the 6 facts now live in section 01) ===== */
.single-fc_case .case-ghero{position:relative;overflow:hidden;height:884px;border-bottom:1px solid var(--line);background:radial-gradient(1000px 780px at 54% 82%,#fdfdff 0%,#e3e8ef 88%);}
.single-fc_case .case-ghero .cghero-globe{position:absolute;inset:0;width:100%;height:100%;display:block;z-index:0;-webkit-mask:linear-gradient(90deg,transparent 12%,#000 54%,#000 100%);mask:linear-gradient(90deg,transparent 12%,#000 54%,#000 100%);}
.single-fc_case .case-ghero .wrap{position:relative;height:100%;z-index:2;}
.single-fc_case .case-ghero .cghero-bottom{position:absolute;left:40px;right:40px;bottom:76px;display:flex;align-items:flex-end;justify-content:space-between;gap:60px;}
.single-fc_case .case-ghero .cghero-copy{flex:1 1 auto;max-width:680px;}
.single-fc_case .case-ghero .eyebrow{display:flex;align-items:center;gap:12px;margin-bottom:0;}
.single-fc_case .case-ghero .eyebrow .bar{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px rgba(31,95,214,.14);}
.single-fc_case .case-ghero .eyebrow .mono{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);white-space:nowrap;}
.single-fc_case .case-ghero h1{font-size:72px;line-height:1.0;letter-spacing:-.04em;font-weight:700;max-width:14ch;color:var(--ink);margin-top:24px;}
.single-fc_case .case-ghero .lead{margin-top:22px;font-size:18px;line-height:1.55;color:var(--ink-2);max-width:46ch;}
.single-fc_case .case-ghero .acts{display:flex;flex-wrap:wrap;gap:12px;margin-top:30px;}
.single-fc_case .m-case-ghero{display:none;}
@media (max-width:768px){
  /* swap desktop globe hero for the mobile one */
  .single-fc_case .case-ghero{display:none;}
  .single-fc_case .m-case-ghero{display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden;min-height:100vh;min-height:calc(100lvh + 10vh);padding:96px 20px 24px;padding:96px 20px calc(100lvh + 10vh - var(--fc-vh, 100svh) + 24px);border-bottom:1px solid var(--line);background:radial-gradient(520px 600px at 50% 46%,#fdfdff 0%,#e3e8ef 86%);}
  .single-fc_case .m-case-ghero .cghero-globe{position:absolute;inset:0;width:100%;height:100%;display:block;z-index:0;}
  .single-fc_case .m-case-ghero .m-cghero-copy{position:relative;z-index:2;}
  .single-fc_case .m-case-ghero .eyebrow{display:flex;align-items:center;gap:10px;margin-bottom:14px;}
  .single-fc_case .m-case-ghero .eyebrow .bar{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 3px rgba(31,95,214,.14);}
  .single-fc_case .m-case-ghero .eyebrow .mono{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);}
  .single-fc_case .m-case-ghero h1{font-size:31px;line-height:1.05;letter-spacing:-.035em;font-weight:700;color:var(--ink);}
  .single-fc_case .m-case-ghero .lead{font-size:14px;color:var(--ink-2);line-height:1.5;margin-top:12px;}
  .single-fc_case .m-case-ghero .m-hero-bottom{position:relative;z-index:3;display:flex;flex-direction:column;align-items:center;gap:14px;}
  .single-fc_case .m-case-ghero .m-hero-bottom .btn{width:100%;justify-content:center;}
}
/* ===== /fc-case-globe-v1 ===== */

/* ===== fc-case-mobile-v1 · case-detail mobile DOM (design .ab-m), display-swapped from desktop ===== */
.single-fc_case .m-svc-sec,.single-fc_case .m-scope,.single-fc_case .m-case-quote{display:none;}
@media (max-width:768px){
  /* swap desktop content sections for the mobile DOM */
  .single-fc_case .svc-ov,.single-fc_case .blocks,.single-fc_case .svc-sec,.single-fc_case .case-quote{display:none;}
  .single-fc_case .m-svc-sec{display:block;padding:var(--sec-y) 20px;position:relative;isolation:isolate;}
  .single-fc_case .m-svc-sec::before{content:"";position:absolute;top:0;left:0;right:0;height:340px;z-index:-1;pointer-events:none;}
  .single-fc_case .m-seclab{display:flex;align-items:center;gap:9px;white-space:nowrap;font-family:var(--mono);font-size:12px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3);}
  .single-fc_case .m-seclab .bar{display:none;}
  .single-fc_case .m-seclab .n{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:6px;background:var(--accent);color:#fff;font-size:10px;font-weight:500;letter-spacing:0;line-height:1;box-shadow:0 4px 12px -4px rgba(31,95,214,.55);flex:none;}
  .single-fc_case .m-seclab .n::after{content:none;}
  .single-fc_case .m-svc-sec h2{font-size:24px;letter-spacing:-.025em;margin:13px 0 12px;line-height:1.1;}
  .single-fc_case .m-svc-sec .ovp{font-size:14px;color:var(--ink-2);line-height:1.65;margin-bottom:12px;}
  /* phase blocks (design .m-cb) */
  .single-fc_case .m-cb{border-top:1px solid var(--line);padding-top:22px;}
  .single-fc_case .m-cb + .m-cb{margin-top:30px;}
  .single-fc_case .m-cb .dlab{display:inline-flex;align-items:center;gap:9px;white-space:nowrap;font-family:var(--mono);font-size:12px;font-weight:600;letter-spacing:.02em;margin-bottom:var(--eyb-gap);}
  .single-fc_case .m-cb .dlab .s{color:var(--accent);}
  .single-fc_case .m-cb .dlab .l{color:var(--ink);text-transform:lowercase;letter-spacing:.04em;}
  .single-fc_case .m-cb h3{font-size:21px;font-weight:500;letter-spacing:-.015em;line-height:1.15;margin:13px 0 9px;}
  .single-fc_case .m-cb p{font-size:13px;color:var(--ink-2);line-height:1.6;}
  .single-fc_case .m-cb .img{position:relative;height:180px;background:#dcd8cf;overflow:hidden;margin-top:14px;border:1px solid var(--line);}
  .single-fc_case .m-cb .pts{margin-top:14px;}
  .single-fc_case .m-cb .pt{display:grid;grid-template-columns:20px 1fr;gap:10px;padding:9px 0;border-bottom:1px solid var(--line);align-items:baseline;}
  .single-fc_case .m-cb .pt .pn{font-family:var(--mono);font-size:10px;color:var(--accent);}
  .single-fc_case .m-cb .pt .pv{font-size:13px;}
  /* werkpakket accordion (design .m-scope) */
  .single-fc_case .m-scope{display:block;padding:30px 20px;background:radial-gradient(720px 340px at var(--gx,50%) -10%,rgba(31,95,214,.13),transparent 72%),var(--bg-2);border-top:1px solid var(--line);}
  .single-fc_case .m-scope h2{font-size:24px;letter-spacing:-.025em;margin:13px 0 8px;}
  .single-fc_case .m-scope .intro{font-size:13px;color:var(--ink-2);line-height:1.55;margin-bottom:16px;}
  .single-fc_case .m-scope .acc{border:1px solid var(--line);background:var(--paper);}
  .single-fc_case .m-scope details{border-top:1px solid var(--line);}
  .single-fc_case .m-scope details:first-child{border-top:0;}
  .single-fc_case .m-scope summary{list-style:none;cursor:pointer;display:grid;grid-template-columns:1fr 22px;gap:12px;align-items:center;padding:14px;}
  .single-fc_case .m-scope summary::-webkit-details-marker{display:none;}
  .single-fc_case .m-scope summary .k{font-family:var(--mono);font-size:10.5px;text-transform:uppercase;color:var(--ink);}
  .single-fc_case .m-scope summary .v{font-size:12px;color:var(--ink-2);margin-top:3px;}
  .single-fc_case .m-scope summary .pm{justify-self:end;width:22px;height:22px;border-radius:3px;border:1px solid var(--line-2);background:var(--paper);display:inline-flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:15px;line-height:1;}
  .single-fc_case .m-scope details[open] summary{background:var(--bg);}
  .single-fc_case .m-scope details[open] summary .pm{background:var(--ink);border-color:var(--ink);color:#fff;}
  .single-fc_case .m-scope details[open] summary .pm .plus{display:none;}
  .single-fc_case .m-scope summary .pm .min{display:none;}
  .single-fc_case .m-scope details[open] summary .pm .min{display:inline;}
  .single-fc_case .m-scope .more{padding:0 14px 14px;background:var(--bg);}
  .single-fc_case .m-scope .more p{margin:0;font-size:12.5px;color:var(--ink-2);line-height:1.6;}
  /* timeline (design .m-case-flow) */
  .single-fc_case .m-case-flow{position:relative;margin-top:16px;padding-left:26px;}
  .single-fc_case .m-case-flow::before{content:"";position:absolute;top:6px;bottom:6px;left:8px;width:2px;background:linear-gradient(180deg,rgba(31,95,214,.5),rgba(31,95,214,.16));}
  .single-fc_case .m-case-flow .st{position:relative;padding:0 0 20px;}
  .single-fc_case .m-case-flow .st:last-child{padding-bottom:0;}
  .single-fc_case .m-case-flow .st .node{position:absolute;left:-26px;top:2px;width:18px;height:18px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px var(--bg);}
  .single-fc_case .m-case-flow .st .wk{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);}
  .single-fc_case .m-case-flow .st h4{font-size:16px;letter-spacing:-.02em;margin-top:5px;}
  .single-fc_case .m-case-flow .st p{font-size:13px;color:var(--ink-2);line-height:1.55;margin-top:6px;}
  /* quote (design .m-case-quote) */
  .single-fc_case .m-case-quote{display:block;padding:30px 20px;}
  .single-fc_case .m-vd-quote-card{position:relative;background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:28px 22px 22px;box-shadow:0 18px 40px -32px rgba(30,42,64,.5);}
  .single-fc_case .m-vd-q-mark{position:absolute;top:8px;left:16px;font-size:56px;line-height:1;color:rgba(31,95,214,.16);font-weight:700;font-family:var(--sans);}
  .single-fc_case .m-vd-quote{font-size:20px;line-height:1.4;letter-spacing:-.02em;position:relative;margin:0;}
  .single-fc_case .m-vd-quote-a{margin-top:16px;font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);}
  /* related cases · compact horizontal cards (matches .m-cs-card; fc-cases-compact-v1) */
  .single-fc_case .m-case-rel{display:flex;flex-direction:column;gap:11px;margin-top:16px;}
  .single-fc_case .m-case-rel a{display:grid;grid-template-columns:78px 1fr;gap:13px;align-items:center;padding:11px;border:1px solid var(--line);border-radius:13px;background:var(--paper);text-decoration:none;color:inherit;}
  .single-fc_case .m-case-rel .thumb{width:78px;height:78px;border-radius:9px;position:relative;overflow:hidden;background:#cdd1d6;}
  .single-fc_case .m-case-rel .thumb .img-slot--todo{position:absolute;inset:0;width:100%;height:100%;}
  .single-fc_case .m-case-rel .b{min-width:0;}
  .single-fc_case .m-case-rel .who{font-family:var(--mono);font-size:9.5px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3);}
  .single-fc_case .m-case-rel h4{font-size:14.5px;font-weight:500;letter-spacing:-.01em;margin-top:4px;line-height:1.25;}
  .single-fc_case .m-case-rel .yr{margin-top:6px;font-family:var(--mono);font-size:9.5px;color:var(--ink-3);}
  /* facts card-grid under the opgave text (design .m-facts) */
  .single-fc_case .m-svc-sec .m-facts{display:grid;grid-template-columns:1fr 1fr;gap:1px;margin-top:22px;background:var(--line);border:1px solid var(--line);border-radius:12px;overflow:hidden;}
  .single-fc_case .m-svc-sec .m-facts > div{background:var(--bg);padding:14px;}
  .single-fc_case .m-svc-sec .m-facts .k{font-family:var(--mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);}
  .single-fc_case .m-svc-sec .m-facts .v{font-size:14px;color:var(--ink);margin-top:5px;font-weight:500;}
  .single-fc_case .m-svc-sec .m-facts .v.cls{color:var(--accent);}
}
/* ===== /fc-case-mobile-v1 ===== */

/* ===== fc-scrollhint-v1 · mobile hero scroll-down chevron (flex-column bottom item; mobile only) ===== */
.m-scrollhint{display:none;}
@media (max-width:768px){
  .m-scrollhint{position:relative;z-index:3;width:28px;height:24px;display:flex;align-items:center;justify-content:center;align-self:center;}
  .m-scrollhint span{width:11px;height:11px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg);animation:scrollbob 1.6s ease-in-out infinite;}
  .hero .m-scrollhint{margin-top:14px;}   /* home/careers: hint sits below the CTA inside .left */
}
@keyframes scrollbob{0%,100%{transform:rotate(45deg) translate(-2px,-2px);opacity:.4;}50%{transform:rotate(45deg) translate(2px,2px);opacity:1;}}
@media (prefers-reduced-motion:reduce){.m-scrollhint span{animation:none;}}
.hero .m-scrollhint{color:#fff;}                                   /* home + careers (dark hero) */
.post-type-archive-fc_case .m-cs-ghero .m-scrollhint{color:#fff;}  /* cases (dark) */
.single-fc_case .m-case-ghero .m-scrollhint{color:var(--ink-3);}   /* case-detail (light) */
/* ===== /fc-scrollhint-v1 ===== */

/* Group 3 responsive */
@media (max-width:768px){
  .post-type-archive-fc_case .cs-hero{padding-top:120px;}
  .post-type-archive-fc_case .cs-hero h1{font-size:38px;}
  .post-type-archive-fc_case .cs-feat .in{display:block;}
  .cs-grid{grid-template-columns:1fr;}
  .post-type-archive-fc_case .cs-head{display:block;}
  .post-type-archive-fc_case .cs-filters{margin-top:14px;flex-wrap:wrap;}
  .single-fc_case .svc-hero{padding-top:120px;}
  .single-fc_case .svc-hero .row{display:block;}
  .single-fc_case .svc-hero h1{font-size:36px;}
  .single-fc_case .svc-hero .meta{border-left:0;padding-left:0;margin-top:24px;padding-top:20px;border-top:1px solid var(--line);display:grid;grid-template-columns:1fr 1fr;gap:16px;}
  .single-fc_case .svc-heroimg{height:240px;}
  .single-fc_case .cb{display:flex;flex-direction:column;gap:18px;}
  .single-fc_case .cb.flip{flex-direction:column-reverse;}
  .single-fc_case .cs-stats{grid-template-columns:1fr 1fr;}
  .single-fc_case .svc-cta .in{padding:24px 20px;}
}
@media (max-width:480px){
  .post-type-archive-fc_case .cs-hero h1{font-size:32px;}
  .single-fc_case .svc-hero h1{font-size:30px;}
}

/* i18n (Polylang) language switcher: menu items rendered as <a> links
   (the artboard used <button>); mirror the .flag-menu button styling. */
.flag-menu a{display:flex;align-items:center;gap:11px;padding:10px 11px;color:rgba(255,255,255,.82);font-family:var(--sans);font-size:13.5px;border-radius:8px;text-decoration:none;}
.flag-menu a:hover{background:rgba(255,255,255,.1);color:#fff;}
.flag-menu a[aria-current="true"]{color:#fff;background:rgba(255,255,255,.06);}
.flag-menu .fl{width:22px;height:15px;border-radius:3px;display:block;box-shadow:0 0 0 1px rgba(255,255,255,.35);flex:0 0 auto;}
.m-flag2 a{display:inline-flex;align-items:center;gap:7px;color:inherit;text-decoration:none;}
.m-flag2 a[aria-current="true"]{color:#fff;}
.m-flag2 .en{width:20px;height:14px;border-radius:3px;display:block;box-shadow:0 0 0 1px rgba(255,255,255,.35);}

/* ===== vacature detail (.page-template-vacancy-detail) ===== */
.page-template-vacancy-detail .vd-sec{padding:var(--sec-y) 0;}
.page-template-vacancy-detail section.vd-sec:first-of-type{padding-top:120px;padding-bottom:58px;}
.page-template-vacancy-detail .vd-sec+.vd-sec{border-top:0;}
.page-template-vacancy-detail .vd-sec:nth-of-type(odd){--gx:28%;}
.page-template-vacancy-detail .vd-sec:nth-of-type(even){--gx:76%;}
.page-template-vacancy-detail .vd-sec::before{display:none;}
.page-template-vacancy-detail .eyebrow{display:flex;align-items:center;gap:12px;}
.page-template-vacancy-detail .eyebrow .bar{width:26px;height:1px;background:#6b7686;}
.page-template-vacancy-detail .vd-hero{display:grid;grid-template-columns:1.32fr .88fr;gap:56px;align-items:start;margin-top:26px;}
.page-template-vacancy-detail .vd-h1{font-size:62px;line-height:1.0;letter-spacing:-.045em;margin-top:18px;}
.page-template-vacancy-detail .vd-lead{margin-top:26px;font-size:23px;line-height:1.42;letter-spacing:-.01em;color:var(--ink);max-width:42ch;}
.page-template-vacancy-detail .vd-rule{border:0;height:1px;background:var(--line-2);margin:26px 0 22px;max-width:520px;}
.page-template-vacancy-detail .vd-more{font-size:15.5px;line-height:1.62;color:var(--ink-2);max-width:56ch;}
.page-template-vacancy-detail .vd-strip{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px;}
.page-template-vacancy-detail .vd-chip{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line-2);background:var(--paper);border-radius:999px;padding:8px 14px;font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--ink-2);}
.page-template-vacancy-detail .vd-chip .d{width:6px;height:6px;border-radius:50%;background:var(--accent);}
.page-template-vacancy-detail .vd-hero-l .ctas{display:flex;flex-wrap:wrap;gap:12px;margin-top:30px;}
.page-template-vacancy-detail .vd-hero-l .ctas .btn{margin-top:0;}
.page-template-vacancy-detail .vd-facts{border-radius:16px;overflow:hidden;background:radial-gradient(620px 420px at 88% -16%,#1c2942,#0e1118 74%);padding:8px 30px;align-self:start;}
.page-template-vacancy-detail .vd-fact{padding:20px 0;border-bottom:1px solid rgba(255,255,255,.1);}
.page-template-vacancy-detail .vd-fact:last-child{border-bottom:0;}
.page-template-vacancy-detail .vd-fact .k{color:#7fb0ff;}
.page-template-vacancy-detail .vd-fact .v{font-size:21px;font-weight:600;letter-spacing:-.02em;color:#fff;margin-top:7px;}
.page-template-vacancy-detail .vd-fact .s{color:#9aa3b2;margin-top:5px;}
.page-template-vacancy-detail .dlabel{display:flex;align-items:center;gap:12px;margin-bottom:30px;}
.page-template-vacancy-detail .dlabel .dl-bar{width:26px;height:1px;background:#6b7686;}
.page-template-vacancy-detail .vd-sechead{margin-bottom:30px;}
.page-template-vacancy-detail .vd-sechead .dlabel{margin-bottom:0;}
.page-template-vacancy-detail .vd-intro-line{font-size:16px;color:var(--ink-2);line-height:1.6;max-width:72ch;margin-top:14px;}
.page-template-vacancy-detail .vd-week{display:grid;grid-template-columns:.82fr 1.18fr;gap:56px;margin-top:6px;align-items:start;}
.page-template-vacancy-detail .vd-week-lead{font-size:15px;color:var(--ink-2);line-height:1.6;}
.page-template-vacancy-detail .vd-week-h{font-size:34px;letter-spacing:-.03em;margin-top:22px;}
.page-template-vacancy-detail .vd-week-o{font-size:15px;color:var(--ink-3);margin-top:12px;}
.page-template-vacancy-detail .vd-timeline{display:flex;flex-direction:column;}
.page-template-vacancy-detail .vd-day{padding:20px 0 20px 26px;border-left:1px solid var(--line-2);position:relative;}
.page-template-vacancy-detail .vd-day::before{content:"";position:absolute;left:-4.5px;top:24px;width:8px;height:8px;border-radius:50%;background:var(--accent);}
.page-template-vacancy-detail .vd-day:first-child{padding-top:2px;}
.page-template-vacancy-detail .vd-day:first-child::before{top:6px;}
.page-template-vacancy-detail .vd-day .d{color:var(--accent);}
.page-template-vacancy-detail .vd-day .t{font-size:18px;font-weight:600;letter-spacing:-.02em;margin-top:7px;}
.page-template-vacancy-detail .vd-day p{font-size:14.5px;color:var(--ink-2);line-height:1.6;margin-top:7px;max-width:62ch;}
.page-template-vacancy-detail .vd-bo{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:6px;}
.page-template-vacancy-detail .vd-bo-col{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:32px 32px 34px;}
.page-template-vacancy-detail .vd-bo-col.alt{background:radial-gradient(640px 460px at 90% -20%,#1c2942,#0e1118 76%);border-color:transparent;}
.page-template-vacancy-detail .vd-bo-col h3{font-size:23px;letter-spacing:-.025em;}
.page-template-vacancy-detail .vd-bo-col.alt h3{color:#fff;}
.page-template-vacancy-detail .vd-list{list-style:none;margin:22px 0 0;padding:0;display:flex;flex-direction:column;gap:14px;}
.page-template-vacancy-detail .vd-list li{display:flex;gap:13px;font-size:15px;line-height:1.5;color:var(--ink-2);}
.page-template-vacancy-detail .vd-bo-col.alt .vd-list li{color:#c7cdd6;}
.page-template-vacancy-detail .vd-list .b{flex:none;width:7px;height:7px;border-radius:2px;background:var(--ink-3);margin-top:7px;}
.page-template-vacancy-detail .vd-list .b.ac{background:var(--accent);}
.page-template-vacancy-detail .vd-bo-col.alt .vd-list .b.ac{background:#7fb0ff;}
.page-template-vacancy-detail .vd-salpanel{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:40px 44px;box-shadow:0 28px 60px -44px rgba(30,42,64,.5);margin-top:6px;}
.page-template-vacancy-detail .sal-top{display:flex;justify-content:space-between;align-items:flex-start;gap:40px;}
.page-template-vacancy-detail .sal-lead{max-width:58ch;}
.page-template-vacancy-detail .sal-title{font-size:26px;letter-spacing:-.03em;line-height:1.12;}
.page-template-vacancy-detail .sal-lead p{margin-top:16px;font-size:15px;color:var(--ink-2);line-height:1.62;}
.page-template-vacancy-detail .sal-tag{flex:none;color:var(--ink-3);border:1px solid var(--line-2);border-radius:999px;padding:8px 15px;}
.page-template-vacancy-detail .sal-track{margin-top:34px;border-top:1px solid var(--line);padding-top:34px;}
.page-template-vacancy-detail .sal-amts{display:grid;grid-template-columns:repeat(3,1fr);text-align:center;}
.page-template-vacancy-detail .sal-amts span{font-size:24px;font-weight:600;letter-spacing:-.025em;}
.page-template-vacancy-detail .sal-amts span.ac{color:var(--accent);}
.page-template-vacancy-detail .sal-line{position:relative;display:grid;grid-template-columns:repeat(3,1fr);align-items:center;height:30px;margin:16px 0;}
.page-template-vacancy-detail .sal-line::before{content:"";position:absolute;left:16.666%;right:16.666%;top:50%;transform:translateY(-50%);height:5px;border-radius:3px;background:linear-gradient(90deg,#bcd0f4,#1f5fd6);}
.page-template-vacancy-detail .sal-line .dot{justify-self:center;position:relative;z-index:1;width:15px;height:15px;border-radius:50%;background:#fff;border:3px solid #1f5fd6;box-shadow:0 0 0 5px rgba(31,95,214,.1);}
.page-template-vacancy-detail .sal-line .dot.end{box-shadow:0 0 0 5px rgba(31,95,214,.16),0 0 18px rgba(31,95,214,.4);}
.page-template-vacancy-detail .sal-roles{display:grid;grid-template-columns:repeat(3,1fr);text-align:center;}
.page-template-vacancy-detail .sal-roles span{color:var(--ink-3);}
.page-template-vacancy-detail .sal-foot{display:flex;justify-content:space-between;align-items:center;gap:40px;border-top:1px solid var(--line);margin-top:34px;padding-top:28px;}
.page-template-vacancy-detail .sal-foot p{font-size:14.5px;color:var(--ink-2);line-height:1.6;max-width:64ch;}
.page-template-vacancy-detail .sal-foot p b{color:var(--ink);font-weight:600;}
.page-template-vacancy-detail .sal-cta{flex:none;padding-left:0;padding-right:0;color:var(--accent);background:none;}
.page-template-vacancy-detail .sal-cta:hover{background:none;box-shadow:none;color:var(--accent-ink);}
.page-template-vacancy-detail .vd-quote-card{position:relative;background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:44px 48px 38px;box-shadow:0 28px 60px -44px rgba(30,42,64,.5);}
.page-template-vacancy-detail .vd-q-mark{position:absolute;top:18px;left:34px;font-size:90px;line-height:1;color:rgba(31,95,214,.16);font-family:var(--sans);font-weight:700;}
.page-template-vacancy-detail .vd-quote{font-size:30px;line-height:1.36;letter-spacing:-.025em;max-width:34ch;color:var(--ink);position:relative;}
.page-template-vacancy-detail .vd-quote-a{margin-top:22px;color:var(--ink-3);}
.page-template-vacancy-detail .vd-proces{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1px;margin-top:6px;border-radius:16px;overflow:hidden;background:#dfe2e7;box-shadow:0 30px 62px -40px rgba(30,42,64,.5);}
.page-template-vacancy-detail .vd-step{background:linear-gradient(165deg,#fafbfc 0%,#ebedf0 100%);padding:26px 22px 24px;display:flex;flex-direction:column;transition:background .3s ease;}
.page-template-vacancy-detail .vd-step:hover{background:linear-gradient(165deg,#ffffff 0%,#eef2f7 100%);}
.page-template-vacancy-detail .vd-step.trial{background:linear-gradient(165deg,#eef4fc 0%,#dfeafa 100%);}
.page-template-vacancy-detail .vd-step .n{font-size:30px;font-weight:500;letter-spacing:-.03em;text-transform:none;color:var(--line-2);line-height:1;}
.page-template-vacancy-detail .vd-step.trial .n{color:#7fb0ff;}
.page-template-vacancy-detail .vd-step h4{font-size:18px;letter-spacing:-.015em;margin-top:16px;}
.page-template-vacancy-detail .vd-step p{font-size:13.5px;color:var(--ink-2);line-height:1.6;margin-top:8px;}
.page-template-vacancy-detail .vd-step .star{display:inline-block;margin-top:auto;padding-top:16px;color:var(--accent);}
.page-template-vacancy-detail .vd-trial{border-radius:18px;overflow:hidden;background:radial-gradient(960px 520px at 80% -18%,#1c2942,#0e1118 74%);padding:40px 44px;}
.page-template-vacancy-detail .vd-trial-h{display:flex;align-items:center;gap:10px;}
.page-template-vacancy-detail .vd-trial-h .mono{color:#7fb0ff;}
.page-template-vacancy-detail .dot-pulse{width:9px;height:9px;border-radius:50%;background:#5ce0a0;box-shadow:0 0 0 0 rgba(92,224,160,.5);animation:vd-pulse 2s infinite;}
@keyframes vd-pulse{0%{box-shadow:0 0 0 0 rgba(92,224,160,.5);}70%{box-shadow:0 0 0 8px rgba(92,224,160,0);}100%{box-shadow:0 0 0 0 rgba(92,224,160,0);}}
.page-template-vacancy-detail .vd-trial-grid{display:grid;grid-template-columns:1fr 1fr;gap:44px;margin-top:22px;align-items:start;}
.page-template-vacancy-detail .vd-trial-grid h3{font-size:30px;letter-spacing:-.03em;color:#fff;}
.page-template-vacancy-detail .vd-trial-grid p{margin-top:14px;font-size:15px;color:#aab2bf;line-height:1.62;}
.page-template-vacancy-detail .vd-trial-grid .vd-list li{color:#c7cdd6;}
.page-template-vacancy-detail .vd-team{display:grid;grid-template-columns:1.06fr .94fr;gap:48px;margin-top:6px;align-items:start;}
.page-template-vacancy-detail .vd-team-cta{display:flex;align-items:center;gap:20px;margin-top:28px;flex-wrap:wrap;}
.page-template-vacancy-detail .vd-team-cta-note{font-size:13.5px;color:var(--ink-3);line-height:1.5;max-width:32ch;}
.page-template-vacancy-detail .vd-team-h{font-size:32px;letter-spacing:-.03em;}
.page-template-vacancy-detail .vd-team p{margin-top:16px;font-size:15px;color:var(--ink-2);line-height:1.62;max-width:50ch;}
.page-template-vacancy-detail .vd-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.page-template-vacancy-detail .vd-stat{background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:22px 18px;text-align:center;}
.page-template-vacancy-detail .vd-stat .n{font-size:24px;font-weight:600;letter-spacing:-.03em;}
.page-template-vacancy-detail .vd-stat .l{margin-top:8px;color:var(--ink-3);}
@media (max-width:768px){
  .page-template-vacancy-detail section.vd-sec:first-of-type{padding-top:104px;padding-bottom:36px;}
  .page-template-vacancy-detail .vd-sec{padding:var(--sec-y) 0;}
  .page-template-vacancy-detail .vd-hero{grid-template-columns:1fr;gap:28px;margin-top:18px;}
  .page-template-vacancy-detail .vd-h1{font-size:38px;}
  .page-template-vacancy-detail .vd-lead{font-size:19px;max-width:none;margin-top:18px;}
  .page-template-vacancy-detail .vd-more{max-width:none;}
  .page-template-vacancy-detail .vd-hero-l .ctas{flex-direction:column;}
  .page-template-vacancy-detail .vd-hero-l .ctas .btn{width:100%;justify-content:center;}
  .page-template-vacancy-detail .vd-facts{padding:6px 20px;}
  .page-template-vacancy-detail .vd-fact .v{font-size:18px;}
  .page-template-vacancy-detail .vd-week{grid-template-columns:1fr;gap:22px;}
  .page-template-vacancy-detail .vd-week-h{font-size:26px;margin-top:14px;}
  .page-template-vacancy-detail .vd-day p{max-width:none;}
  .page-template-vacancy-detail .vd-bo{grid-template-columns:1fr;gap:14px;}
  .page-template-vacancy-detail .vd-bo-col{padding:24px 22px 26px;}
  .page-template-vacancy-detail .vd-salpanel{padding:26px 22px;}
  .page-template-vacancy-detail .sal-top{flex-direction:column;gap:14px;}
  .page-template-vacancy-detail .sal-foot{flex-direction:column;align-items:flex-start;gap:16px;}
  .page-template-vacancy-detail .vd-quote-card{padding:34px 24px 30px;}
  .page-template-vacancy-detail .vd-quote{font-size:22px;max-width:none;}
  .page-template-vacancy-detail .vd-proces{grid-template-columns:1fr 1fr;}
  .page-template-vacancy-detail .vd-trial{padding:28px 22px;}
  .page-template-vacancy-detail .vd-trial-grid{grid-template-columns:1fr;gap:20px;}
  .page-template-vacancy-detail .vd-trial-grid h3{font-size:24px;}
  .page-template-vacancy-detail .vd-trial-grid .btn{width:100%;justify-content:center;}
  .page-template-vacancy-detail .vd-team{grid-template-columns:1fr;gap:24px;}
  .page-template-vacancy-detail .vd-team-h{font-size:26px;}
  .page-template-vacancy-detail .vd-team-cta .btn{width:100%;justify-content:center;}
}
@media (max-width:480px){
  .page-template-vacancy-detail .vd-h1{font-size:32px;}
  .page-template-vacancy-detail .vd-proces{grid-template-columns:1fr;}
  .page-template-vacancy-detail .vd-stats{grid-template-columns:1fr;}
  .page-template-vacancy-detail .vd-chip{font-size:10px;padding:7px 12px;}
}

/* ===== vacature detail · mobile salary track (vertical rows) ===== */
.page-template-vacancy-detail .sal-rows{display:none;}
@media (max-width:768px){
  .page-template-vacancy-detail .sal-track{display:none;}
  .page-template-vacancy-detail .sal-tag{display:none;}
  .page-template-vacancy-detail .sal-title{font-size:20px;}
  .page-template-vacancy-detail .sal-lead p{font-size:14px;}
  .page-template-vacancy-detail .sal-rows{display:flex;flex-direction:column;margin-top:18px;}
  /* rows as a grid: [dot 12px | role 1fr | amount auto] */
  .page-template-vacancy-detail .sal-rows .sal-row{position:relative;display:grid;grid-template-columns:12px 1fr auto;align-items:center;column-gap:12px;padding:11px 0;}
  /* one continuous timeline centred on the dot column (dot centre = 6px, so line
     left:5px). The first row starts the line at its dot centre, the last row stops
     it at its dot centre, so it runs exactly dot-to-dot with no overshoot and no
     gaps, passing behind the 'Na promotie' label too. */
  .page-template-vacancy-detail .sal-rows .sal-row::before,
  .page-template-vacancy-detail .sal-rows .sal-grouplbl.next::before{content:"";position:absolute;left:5px;top:0;bottom:0;width:2px;background:var(--line-2);z-index:0;}
  .page-template-vacancy-detail .sal-rows .sal-row:not(.cur):not(.end)::before{top:50%;}
  .page-template-vacancy-detail .sal-rows .sal-row.end::before{bottom:50%;}
  .page-template-vacancy-detail .sal-rows .dot{position:relative;z-index:1;width:12px;height:12px;border-radius:50%;background:#fff;border:2.5px solid var(--accent);}
  .page-template-vacancy-detail .sal-rows .sal-row.cur .dot{box-shadow:0 0 0 4px rgba(31,95,214,.16);}
  .page-template-vacancy-detail .sal-rows .sal-row.end .dot{border-color:var(--line-2);}
  .page-template-vacancy-detail .sal-rows .role{font-family:var(--mono);font-size:13.5px;color:var(--ink-3);}
  .page-template-vacancy-detail .sal-rows .sal-row.cur .role{color:var(--ink);}
  .page-template-vacancy-detail .sal-rows .amt{justify-self:end;font-size:16px;font-weight:600;letter-spacing:-.02em;color:var(--ink);}
  .page-template-vacancy-detail .sal-rows .amt.ac{color:var(--accent);}
  .page-template-vacancy-detail .sal-rows .amt.next{color:var(--ink-3);font-weight:500;}
  /* group labels indented to the role column (12px dot + 12px gap = 24px) */
  .page-template-vacancy-detail .sal-rows .sal-grouplbl{position:relative;font-family:var(--mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);padding:2px 0 8px 24px;}
  .page-template-vacancy-detail .sal-rows .sal-grouplbl.next{color:var(--ink-3);padding:12px 0 8px 24px;}
  .page-template-vacancy-detail .sal-foot{margin-top:18px;padding-top:18px;}
  .page-template-vacancy-detail .sal-foot .sal-cta{width:100%;justify-content:center;border:1px solid var(--line-2);background:var(--paper);padding:11px 18px;margin-top:4px;}
}

/* ===== service detail · mobile pixel pass (design .ab-m) ===== */
.page-template-service-detail .svc-acc{display:none;}
@media (max-width:768px){
  /* section labels: blue badge number, no bar (design .m-seclab) */
  .page-template-service-detail .seclab{gap:9px;font-size:12px;letter-spacing:.04em;}
  .page-template-service-detail .seclab .bar{display:none;}
  .page-template-service-detail .seclab .n{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:6px;background:var(--accent);color:#fff;font-size:10px;font-weight:500;letter-spacing:0;line-height:1;box-shadow:0 4px 12px -4px rgba(31,95,214,.55);flex:none;}
  .page-template-service-detail .seclab .n::after{content:none;}

  /* hero (design .m-svc-hero) */
  .page-template-service-detail .svc-hero{padding:90px 0 var(--sec-y);}
  .page-template-service-detail .svc-hero .row{display:block;}
  .page-template-service-detail .svc-hero .eyebrow{gap:10px;margin-bottom:12px;}
  .page-template-service-detail .svc-hero .eyebrow .bar{width:20px;}
  .page-template-service-detail .svc-hero .eyebrow .mono{font-size:10px;letter-spacing:.1em;}
  .page-template-service-detail .svc-hero h1{font-size:33px;line-height:1.04;letter-spacing:-.035em;}
  .page-template-service-detail .svc-hero .lead{font-size:14.5px;line-height:1.55;margin-top:14px;max-width:none;}
  .page-template-service-detail .svc-hero .acts{margin-top:16px;}
  .page-template-service-detail .svc-hero .acts .btn{width:100%;justify-content:center;}
  .page-template-service-detail .svc-hero .meta{border-left:0;padding-left:0;margin-top:24px;padding-top:22px;display:grid;grid-template-columns:1fr 1fr;gap:18px;}
  .page-template-service-detail .svc-hero .meta .k{font-family:var(--mono);font-size:9.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);}
  .page-template-service-detail .svc-hero .meta .v{font-size:13px;margin-top:4px;line-height:1.4;}

  /* hero image (design .m-svc-heroimg) */
  .page-template-service-detail .svc-heroimg{height:212px;}

  /* overview (design .m-svc-sec) */
  .page-template-service-detail .svc-ov{padding-top:30px;padding-bottom:30px;}
  .page-template-service-detail .svc-wp .ov-h{font-size:24px;letter-spacing:-.025em;line-height:1.1;margin:13px 0 12px;}
  .page-template-service-detail .svc-ov .ov-intro{display:block;}
  .page-template-service-detail .svc-ov .ov-intro .lead p{font-size:14px;color:var(--ink-2);line-height:1.65;}
  .page-template-service-detail .svc-ov .ov-intro .lead p + p{margin-top:12px;}
  .page-template-service-detail .svc-ov .ov-stats{display:none;} /* design omits stats on mobile */

  /* werkpakket: hide the desktop radio-tab list, show all panes as a card list
     (design uses a collapsible accordion; this shows the same content, expanded) */
  .page-template-service-detail .svc-ov .wp-head{flex-direction:column;align-items:flex-start;gap:4px;margin-top:28px;}
  .page-template-service-detail .svc-ov .wp-head .t{font-size:18px;}
  .page-template-service-detail .md{display:none;}
  .page-template-service-detail .svc-acc{display:block;border:1px solid var(--line);background:var(--paper);margin-top:16px;}
  .page-template-service-detail .svc-acc details{border-top:1px solid var(--line);}
  .page-template-service-detail .svc-acc details:first-child{border-top:0;}
  .page-template-service-detail .svc-acc summary{list-style:none;cursor:pointer;display:grid;grid-template-columns:1fr 22px;gap:12px;align-items:center;padding:14px;}
  .page-template-service-detail .svc-acc summary::-webkit-details-marker{display:none;}
  .page-template-service-detail .svc-acc summary .k{font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink);}
  .page-template-service-detail .svc-acc summary .v{font-size:12px;color:var(--ink-2);margin-top:3px;}
  .page-template-service-detail .svc-acc summary .pm{justify-self:end;width:22px;height:22px;border-radius:3px;border:1px solid var(--line-2);background:var(--paper);display:inline-flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:15px;line-height:1;}
  .page-template-service-detail .svc-acc details[open] summary{background:var(--bg);}
  .page-template-service-detail .svc-acc details[open] summary .pm{background:var(--ink);border-color:var(--ink);color:#fff;}
  .page-template-service-detail .svc-acc summary .pm .min{display:none;}
  .page-template-service-detail .svc-acc details[open] summary .pm .plus{display:none;}
  .page-template-service-detail .svc-acc details[open] summary .pm .min{display:inline;}
  .page-template-service-detail .svc-acc .more{padding:0 14px 14px;background:var(--bg);}
  .page-template-service-detail .svc-acc .more p{margin:0;font-size:12.5px;color:var(--ink-2);line-height:1.6;}

  /* content blocks (design .m-cb): stacked, image on top, bordered between */
  .page-template-service-detail .blocks{padding:var(--sec-y) 20px;}
  .page-template-service-detail .cb{display:flex;flex-direction:column;gap:14px;}
  .page-template-service-detail .cb.flip{flex-direction:column-reverse;}
  .page-template-service-detail .cb + .cb{margin-top:30px;}
  .page-template-service-detail .cb .img{height:180px;min-height:0;border:1px solid var(--line);}
  .page-template-service-detail .cb .txt{align-self:auto;}
  .page-template-service-detail .cb .dlab{font-size:12px;letter-spacing:.04em;}
  .page-template-service-detail .cb .dlab .ln{width:22px;margin-right:11px;}
  .page-template-service-detail .cb h3{font-size:21px;font-weight:500;letter-spacing:-.015em;line-height:1.15;margin:13px 0 9px;}
  .page-template-service-detail .cb p{font-size:13px;line-height:1.6;}
  .page-template-service-detail .cb .pts{margin-top:14px;}
  .page-template-service-detail .cb .pt{display:grid;grid-template-columns:20px 1fr;gap:10px;padding:6px 0;align-items:baseline;}
  .page-template-service-detail .cb .pt .pn{font-family:var(--mono);font-size:10px;color:var(--accent);}
  .page-template-service-detail .cb .pt .pv{font-size:13px;}

  /* approach (design .m-appr): bordered vertical stack, number on top */
  .page-template-service-detail .svc-sec{padding-top:30px !important;padding-bottom:30px !important;}
  .page-template-service-detail .appr-head{flex-direction:column;align-items:flex-start;gap:12px;}
  .page-template-service-detail .appr-head .btn{display:none;} /* design omits the section ghost button on mobile */
  .page-template-service-detail .appr-head h2{font-size:24px;line-height:1.1;}
  .page-template-service-detail .appr-head .intro{font-size:14px;line-height:1.65;}
  .page-template-service-detail .appr{display:flex;flex-direction:column;gap:1px;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#dfe2e7;box-shadow:0 20px 44px -34px rgba(30,42,64,.5);margin-top:16px;}
  .page-template-service-detail .appr .c{display:block;padding:18px;background:linear-gradient(165deg,#fafbfc,#ebedf0);}
  .page-template-service-detail .appr .c .n{font-family:var(--mono);font-size:24px;font-weight:500;letter-spacing:-.03em;color:var(--line-2);line-height:1;}
  .page-template-service-detail .appr .c h4{font-size:17px;font-weight:500;margin-top:10px;letter-spacing:-.01em;}
  .page-template-service-detail .appr .c p{font-size:13px;color:var(--ink-2);line-height:1.55;margin-top:7px;}

  /* cases (design .m-cases / .m-ccard): single column */
  .page-template-service-detail .cases-head{flex-direction:column;align-items:flex-start;gap:12px;}
  .page-template-service-detail .cases-head .btn{display:none;}
  .page-template-service-detail .cases{display:flex;flex-direction:column;gap:14px;margin-top:16px;}
  .page-template-service-detail .ccard{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--paper);}
  .page-template-service-detail .ccard .frame{height:170px;}
  .page-template-service-detail .ccard .body{padding:15px 16px 17px;}
  .page-template-service-detail .ccard .meta{font-size:9.5px;letter-spacing:.05em;}
  .page-template-service-detail .ccard h4{font-size:17px;letter-spacing:-.02em;margin-top:8px;}

  /* CTA (design .m-svc-cta): light card, stacked, full-width button */
  .page-template-service-detail .svc-cta{padding:var(--sec-y) 0;}
  .page-template-service-detail .svc-cta .in{flex-direction:column;align-items:flex-start;gap:0;padding:26px 22px;border-radius:16px;}
  .page-template-service-detail .svc-cta h2{font-size:26px;letter-spacing:-.02em;line-height:1.06;margin:13px 0 10px;}
  .page-template-service-detail .svc-cta p{font-size:13px;}
  .page-template-service-detail .svc-cta .side{width:100%;min-width:0;margin-top:16px;}
  .page-template-service-detail .svc-cta .side .btn{width:100%;justify-content:center;}
  .page-template-service-detail .svc-cta .chip{font-size:9px;gap:7px;padding:4px 9px;}
  .page-template-service-detail .svc-cta .chip .pulse{width:6px;height:6px;}
  .page-template-service-detail .svc-cta .phone{font-size:22px;}

  /* "meer van First Case" (design .m-other): bordered row list, simplified */
  /* #3 mobile "Meer van First Case" / "Meer diensten": separated rounded cards,
     exactly like the homepage services mobile rows (.m-srow). */
  .page-template-service-detail .other{display:flex;flex-direction:column;gap:12px;border:0;border-radius:0;overflow:visible;background:transparent;box-shadow:none;margin-top:16px;}
  .page-template-service-detail .other a{display:grid;grid-template-columns:1fr auto;column-gap:12px;align-items:center;padding:14px 16px;border:1px solid var(--line);border-radius:14px;background:var(--paper);box-shadow:0 14px 30px -26px rgba(30,42,64,.5);}
  .page-template-service-detail .other a .chip,.page-template-service-detail .other a .ix{display:none;}
  .page-template-service-detail .other a h4{grid-column:1;grid-row:1;font-size:15.5px;font-weight:500;letter-spacing:-.015em;margin:0;color:var(--ink);}
  .page-template-service-detail .other a p{grid-column:1;grid-row:2;font-size:11.5px;color:var(--ink-2);line-height:1.35;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  .page-template-service-detail .other a .go{grid-column:2;grid-row:1 / 3;align-self:center;margin:0;padding:0;font-size:0;}
  .page-template-service-detail .other a .go .ar{font-size:14px;color:var(--ink-3);}

  /* product strip (design .m-prodstrip): single stacked block */
  .page-template-service-detail .prodstrip{display:block;border:1px solid var(--line);border-radius:14px;background:linear-gradient(165deg,#fafbfc,#ebedf0);padding:18px;box-shadow:0 20px 44px -34px rgba(30,42,64,.5);margin-top:16px;}
  .page-template-service-detail .prodstrip h4{font-size:18px;font-weight:500;margin-top:11px;letter-spacing:-.015em;}
  .page-template-service-detail .prodstrip p{font-size:13px;color:var(--ink-2);line-height:1.5;margin-top:8px;}
  .page-template-service-detail .prodstrip .ps-r{margin-top:12px;}
  .page-template-service-detail .prodstrip .ps-tags{display:flex;flex-wrap:wrap;gap:6px;}
  .page-template-service-detail .prodstrip .chip.kern{font-size:9px;padding:3px 8px;}
  .page-template-service-detail .prodstrip .ps-tags span{font-size:9px;letter-spacing:.02em;padding:3px 7px;color:var(--ink-2);border-radius:5px;}
  .page-template-service-detail .prodstrip .go{margin-top:14px;font-size:12px;}
}

/* ===== sollicitatie + bedankt (design) ===== */
/* shared light section (design .vd-sec) */
.page-slug-sollicitatie .vd-sec,.page-slug-bedankt .vd-sec{padding:var(--sec-y) 0;}
.page-slug-sollicitatie section.vd-sec:first-of-type,.page-slug-bedankt section.vd-sec:first-of-type{padding-top:120px;padding-bottom:58px;}
.page-slug-sollicitatie .vd-sec::before,.page-slug-bedankt .vd-sec::before{display:none;}

/* --- sollicitatie (desktop) --- */
.page-slug-sollicitatie .apply-panel{display:grid;grid-template-columns:1fr 1.04fr;align-items:stretch;border-radius:18px;overflow:hidden;box-shadow:0 44px 90px -46px rgba(14,17,24,.75);}
.page-slug-sollicitatie .apply-l{padding:48px 46px;display:flex;flex-direction:column;color:#e9e7e2;background:radial-gradient(860px 460px at 14% -18%,rgba(28,41,66,1),rgba(14,17,24,1) 72%);}
.page-slug-sollicitatie .apply-l .secnum .mono{color:rgba(255,255,255,.5);}
.page-slug-sollicitatie .apply-l h2{color:#fff;font-size:30px;letter-spacing:-.025em;margin-top:16px;line-height:1.1;}
.page-slug-sollicitatie .apply-steps{margin-top:38px;display:flex;flex-direction:column;gap:26px;}
.page-slug-sollicitatie .apply-steps .stp{display:flex;align-items:baseline;gap:16px;}
.page-slug-sollicitatie .apply-steps .stp .sn{font-family:var(--mono);font-size:12px;color:#7fb0ff;flex:none;}
.page-slug-sollicitatie .apply-steps .stp .st{color:#fff;font-size:17px;font-weight:600;letter-spacing:-.01em;}
.page-slug-sollicitatie .apply-steps .stp .st .opt{color:#7e889a;font-weight:400;}
.page-slug-sollicitatie .apply-contact{margin-top:auto;padding-top:34px;display:flex;flex-direction:column;gap:20px;}
.page-slug-sollicitatie .apply-contact .ac-row{display:flex;flex-direction:column;gap:6px;text-decoration:none;}
.page-slug-sollicitatie .apply-contact .lbl{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:#9cc0ff;}
.page-slug-sollicitatie .apply-contact .num{font-family:var(--mono);font-size:23px;font-weight:500;color:#fff;letter-spacing:-.01em;display:inline-flex;align-items:center;gap:10px;}
.page-slug-sollicitatie .apply-contact .num .wa-ic{width:19px;height:19px;flex:none;color:#fff;}
.page-slug-sollicitatie .apply-contact .val{font-size:16px;color:#fff;display:inline-flex;align-items:center;gap:8px;}
.page-slug-sollicitatie .apply-contact .val .mail-ic{width:19px;height:19px;flex:none;color:#fff;}
.page-slug-sollicitatie .apply-contact .val .ar{transition:transform .2s ease;}
.page-slug-sollicitatie .apply-contact .ac-row:hover .num,.page-slug-sollicitatie .apply-contact .ac-row:hover .val{color:#cfe0ff;}
.page-slug-sollicitatie .apply-contact .ac-row:hover .val .ar{transform:translateX(4px);}
.page-slug-sollicitatie .apply-form{background:#fff;padding:42px 40px;display:flex;flex-direction:column;justify-content:center;}
.page-slug-sollicitatie .apply-form .ff-label{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);margin-bottom:10px;}
.page-slug-sollicitatie .apply-form .aform-title{font-size:30px;letter-spacing:-.025em;color:var(--ink);line-height:1.1;margin-bottom:20px;max-width:20ch;}
.page-slug-sollicitatie .apply-form .ff-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.page-slug-sollicitatie .apply-form .ff{display:flex;align-items:center;gap:12px;margin-top:10px;border:1px solid var(--line);border-radius:8px;background:var(--bg-2);padding:0 14px;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease;}
.page-slug-sollicitatie .apply-form .ff-row .ff{margin-top:0;}
.page-slug-sollicitatie .apply-form .ff-row .ff-upload{margin-top:0;height:100%;}
.page-slug-sollicitatie .apply-form .ff-row:has(.ff-upload){margin-top:10px;}
.page-slug-sollicitatie .apply-form .ff:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px rgba(31,95,214,.12);background:#fff;}
.page-slug-sollicitatie .apply-form .ff .mono{font-family:var(--mono);font-size:10px;letter-spacing:.06em;color:var(--ink-3);flex:none;}
.page-slug-sollicitatie .apply-form .ff input,.page-slug-sollicitatie .apply-form .ff textarea{flex:1;min-width:0;border:0;background:none;padding:12px 0;font-family:var(--sans);font-size:14px;color:var(--ink);}
.page-slug-sollicitatie .apply-form .ff input:focus,.page-slug-sollicitatie .apply-form .ff textarea:focus{outline:none;}
.page-slug-sollicitatie .apply-form .ff.ta{align-items:flex-start;}
.page-slug-sollicitatie .apply-form .ff.ta .mono{padding-top:12px;}
.page-slug-sollicitatie .apply-form .ff textarea{min-height:84px;resize:vertical;}
.page-slug-sollicitatie .apply-form .ff-upload{display:flex;align-items:center;gap:12px;margin-top:10px;border:1px dashed var(--line-2);border-radius:8px;background:var(--bg-2);padding:14px;cursor:pointer;transition:border-color .2s ease,background .2s ease;}
.page-slug-sollicitatie .apply-form .ff-upload:hover{border-color:var(--accent);background:#fff;}
.page-slug-sollicitatie .apply-form .ff-upload .mono{font-family:var(--mono);font-size:10px;letter-spacing:.06em;color:var(--ink-3);flex:none;}
.page-slug-sollicitatie .apply-form .ff-upload .up-txt{font-size:13px;color:var(--ink-2);}
.page-slug-sollicitatie .apply-form .ff-upload .up-txt b{color:var(--accent);font-weight:500;}
.page-slug-sollicitatie .apply-form .ff-submit{width:100%;justify-content:center;margin-top:20px;padding:13px 26px;}
.page-slug-sollicitatie .apply-form .ff-consent{display:flex;align-items:flex-start;gap:11px;margin-top:20px;cursor:pointer;}
.page-slug-sollicitatie .apply-form .ff-consent input{position:absolute;width:1px;height:1px;opacity:0;}
.page-slug-sollicitatie .apply-form .ff-consent .cs-box{flex:none;width:18px;height:18px;margin-top:1px;border:1px solid var(--line-2);border-radius:5px;background:var(--bg-2);display:flex;align-items:center;justify-content:center;transition:background .15s ease,border-color .15s ease,box-shadow .15s ease;}
.page-slug-sollicitatie .apply-form .ff-consent .cs-box svg{width:11px;height:11px;stroke:#fff;stroke-width:3;fill:none;opacity:0;transition:opacity .15s ease;}
.page-slug-sollicitatie .apply-form .ff-consent input:checked + .cs-box{background:var(--accent);border-color:var(--accent);}
.page-slug-sollicitatie .apply-form .ff-consent input:checked + .cs-box svg{opacity:1;}
.page-slug-sollicitatie .apply-form .ff-consent input:focus-visible + .cs-box{box-shadow:0 0 0 3px rgba(31,95,214,.22);}
.page-slug-sollicitatie .apply-form .ff-consent .cs-txt{font-size:12.5px;color:var(--ink-2);line-height:1.55;}
.page-slug-sollicitatie .apply-form .ff-consent .cs-txt a{color:var(--accent);text-decoration:underline;text-underline-offset:2px;}
.page-slug-sollicitatie .apply-form .ff-note{font-size:12.5px;color:var(--ink-3);margin-top:14px;line-height:1.5;}

/* --- bedankt (desktop) --- */
.page-slug-bedankt .ty{min-height:560px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:48px 40px 96px;}
.page-slug-bedankt .ty-check{width:76px;height:76px;border-radius:50%;border:2px solid var(--accent);display:flex;align-items:center;justify-content:center;color:var(--accent);box-shadow:0 0 0 9px rgba(31,95,214,.07),0 16px 36px -12px rgba(31,95,214,.45);}
.page-slug-bedankt .ty-check svg{width:34px;height:34px;}
.page-slug-bedankt .ty-eyebrow{margin-top:30px;color:var(--accent);}
.page-slug-bedankt .ty-h1{font-size:60px;font-weight:600;letter-spacing:-.04em;line-height:1.0;margin:20px 0 0;max-width:18ch;}
.page-slug-bedankt .ty-body{margin-top:24px;font-size:22px;font-weight:600;letter-spacing:-.01em;color:var(--ink);}
.page-slug-bedankt .ty-sub{margin-top:14px;font-size:16px;color:var(--ink-2);line-height:1.6;max-width:54ch;}
.page-slug-bedankt .ty-cta{display:flex;gap:14px;margin-top:40px;flex-wrap:wrap;justify-content:center;}

@media (max-width:768px){
  .page-slug-sollicitatie .vd-sec,.page-slug-bedankt .vd-sec{padding:var(--sec-y) 0;}
  .page-slug-sollicitatie section.vd-sec:first-of-type,.page-slug-bedankt section.vd-sec:first-of-type{padding-top:96px;padding-bottom:30px;}
  /* sollicitatie mobile: two stacked cards (design .m-apply / .m-aform) */
  .page-slug-sollicitatie .apply-panel{display:block;border-radius:0;overflow:visible;box-shadow:none;}
  .page-slug-sollicitatie .apply-l{border-radius:16px;padding:26px 22px;background:radial-gradient(480px 380px at 84% -14%,#1c2942,#0e1118 74%);}
  .page-slug-sollicitatie .apply-l h2{font-size:22px;margin-top:12px;line-height:1.15;letter-spacing:-.02em;}
  .page-slug-sollicitatie .apply-steps{margin-top:22px;gap:18px;}
  .page-slug-sollicitatie .apply-steps .stp{gap:12px;}
  .page-slug-sollicitatie .apply-steps .stp .sn{font-size:11px;}
  .page-slug-sollicitatie .apply-steps .stp .st{font-size:15px;}
  .page-slug-sollicitatie .apply-contact{margin-top:22px;gap:16px;}
  .page-slug-sollicitatie .apply-contact .lbl{font-size:9px;}
  .page-slug-sollicitatie .apply-contact .num{font-size:19px;gap:8px;}
  .page-slug-sollicitatie .apply-contact .num .wa-ic{width:16px;height:16px;}
  .page-slug-sollicitatie .apply-contact .val{font-size:14px;gap:7px;}
  .page-slug-sollicitatie .apply-contact .val .mail-ic{width:16px;height:16px;}
  .page-slug-sollicitatie .apply-form{border:1px solid var(--line);border-radius:16px;margin-top:14px;padding:22px 20px;box-shadow:0 18px 40px -32px rgba(30,42,64,.5);}
  .page-slug-sollicitatie .apply-form .ff-label{font-size:10px;margin-bottom:8px;}
  .page-slug-sollicitatie .apply-form .aform-title{font-size:22px;line-height:1.18;margin-bottom:14px;letter-spacing:-.02em;max-width:none;}
  .page-slug-sollicitatie .apply-form .ff-row{grid-template-columns:1fr;gap:0;}
  .page-slug-sollicitatie .apply-form .ff-row .ff{margin-top:10px;}
  .page-slug-sollicitatie .apply-form .ff-row .ff-upload{margin-top:10px;height:auto;}
  .page-slug-sollicitatie .apply-form .ff{padding:0 12px;gap:10px;}
  .page-slug-sollicitatie .apply-form .ff .mono{font-size:9px;}
  .page-slug-sollicitatie .apply-form .ff input,.page-slug-sollicitatie .apply-form .ff textarea{padding:11px 0;}
  .page-slug-sollicitatie .apply-form .ff.ta .mono{padding-top:11px;}
  .page-slug-sollicitatie .apply-form .ff textarea{min-height:72px;}
  .page-slug-sollicitatie .apply-form .ff-upload{padding:13px 12px;gap:10px;}
  .page-slug-sollicitatie .apply-form .ff-upload .mono{font-size:9px;}
  .page-slug-sollicitatie .apply-form .ff-upload .up-txt{font-size:12.5px;}
  .page-slug-sollicitatie .apply-form .ff-submit{margin-top:18px;}
  .page-slug-sollicitatie .apply-form .ff-note{font-size:12px;margin-top:12px;}
  /* bedankt mobile */
  .page-slug-bedankt .ty{min-height:0;padding:36px 0 60px;}
  .page-slug-bedankt .ty-check{width:58px;height:58px;box-shadow:0 0 0 7px rgba(31,95,214,.07);}
  .page-slug-bedankt .ty-check svg{width:27px;height:27px;}
  .page-slug-bedankt .ty-eyebrow{margin-top:22px;font-size:10px;}
  .page-slug-bedankt .ty-h1{font-size:34px;letter-spacing:-.035em;line-height:1.04;margin-top:14px;}
  .page-slug-bedankt .ty-body{margin-top:16px;font-size:17px;}
  .page-slug-bedankt .ty-sub{margin-top:12px;font-size:14px;}
  .page-slug-bedankt .ty-cta{flex-direction:column;gap:10px;margin-top:28px;width:100%;}
  .page-slug-bedankt .ty-cta .btn{width:100%;justify-content:center;}
}

/* ===========================================================================
   fc_ats ATS front-end · gaps not covered by the reused page CSS scopes.
   The four ATS templates (themes/firstcase/firstcase-ats/) reuse the approved
   .vac-/.vd-/.apply-/.ty- rules via body classes added in functions.php. Only
   the items below are genuinely new: the archive empty state, the single-job
   the_content() prose, the source <select>, the visible CV input, and on-brand
   form validation states (so candidates never see raw WP errors).
   ========================================================================= */

/* Vacatures · empty state (no open vacancies) */
.page-slug-vacatures .vac-empty{display:flex;flex-direction:column;align-items:flex-start;gap:14px;padding:40px 0 8px;max-width:60ch;}
.page-slug-vacatures .vac-empty .ve-mark{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);}
.page-slug-vacatures .vac-empty .ve-h{font-size:30px;font-weight:600;letter-spacing:-.025em;color:var(--ink);line-height:1.12;}
.page-slug-vacatures .vac-empty .ve-p{font-size:16px;color:var(--ink-2);line-height:1.6;}
.page-slug-vacatures .vac-empty .btn{margin-top:6px;}

/* Vacature detail · plugin the_content() prose + thumbnail + closed note */
.single-fc_job .vd-body{max-width:768px;font-size:16px;line-height:1.7;color:var(--ink-2);}
.single-fc_job .vd-body > *:first-child{margin-top:0;}
.single-fc_job .vd-body p{margin:0 0 16px;}
.single-fc_job .vd-body h2{font-size:24px;font-weight:600;letter-spacing:-.02em;color:var(--ink);margin:34px 0 12px;}
.single-fc_job .vd-body h3{font-size:19px;font-weight:600;letter-spacing:-.015em;color:var(--ink);margin:28px 0 10px;}
.single-fc_job .vd-body ul,.single-fc_job .vd-body ol{margin:0 0 16px;padding-left:20px;}
.single-fc_job .vd-body li{margin:0 0 7px;}
.single-fc_job .vd-body a{color:var(--accent);text-decoration:underline;text-underline-offset:2px;}
.single-fc_job .vd-body strong{color:var(--ink);font-weight:600;}
.single-fc_job .vd-job-thumb img{display:block;width:100%;height:auto;border-radius:14px;}
.single-fc_job .vd-closed{margin-top:18px;font-family:var(--mono);font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);}

/* Sollicitatie · source <select> mirrors the .ff text inputs */
.page-slug-sollicitatie .apply-form .ff select{flex:1;min-width:0;border:0;background:none;padding:12px 0;font-family:var(--sans);font-size:14px;color:var(--ink);cursor:pointer;}
.page-slug-sollicitatie .apply-form .ff select:focus{outline:none;}

/* Sollicitatie · visible CV file input (kept usable on the real apply path) */
.page-slug-sollicitatie .apply-form .ff-upload{flex-wrap:wrap;}
.page-slug-sollicitatie .apply-form .ff-upload input[type=file]{flex-basis:100%;font-size:12.5px;color:var(--ink-2);margin-top:6px;}

/* Sollicitatie · char counter below the textarea */
.page-slug-sollicitatie .apply-form .ff.ta{flex-wrap:wrap;align-items:flex-start;}
.page-slug-sollicitatie .apply-form .ff.ta textarea{flex:1;}
.page-slug-sollicitatie .apply-form .fcats-char-counter{flex-basis:100%;text-align:right;margin-top:4px;font-family:var(--mono);font-size:10px;letter-spacing:.04em;color:var(--ink-3);}

/* Sollicitatie · on-brand validation states (replace raw WP errors) */
.page-slug-sollicitatie .apply-form .ff.fcats-field-error,.page-slug-sollicitatie .apply-form .ff-upload.fcats-field-error{border-color:#c0341d;box-shadow:0 0 0 3px rgba(192,52,29,.12);}
.page-slug-sollicitatie .apply-form .ff-upload.fcats-field-error{border-style:solid;}
.page-slug-sollicitatie .apply-form .fcats-error-message{display:block;flex-basis:100%;width:100%;margin-top:6px;font-family:var(--mono);font-size:11px;letter-spacing:.02em;color:#c0341d;}
.page-slug-sollicitatie .apply-form .ff-error-general{margin-bottom:14px;padding:12px 14px;border:1px solid #c0341d;border-left:3px solid #c0341d;border-radius:8px;background:#fbecea;color:#8f2113;font-size:13.5px;line-height:1.5;}
.page-slug-sollicitatie .apply-form .ff-consent.fcats-field-error .cs-box{border-color:#c0341d;box-shadow:0 0 0 3px rgba(192,52,29,.12);}

/* Sollicitatie file-upload: drag-over + file-attached states (JS toggles the
   .is-drag / .is-filled classes; see assets/js/main.js). Additive over the
   existing .ff-upload rule; applies on /sollicitatie and /open-sollicitatie. */
.page-slug-sollicitatie .apply-form .ff-upload.is-drag{border-style:solid;border-color:var(--accent);background:#fff;}
.page-slug-sollicitatie .apply-form .ff-upload.is-filled{border-style:solid;border-color:var(--accent);}
.page-slug-sollicitatie .apply-form .ff-upload.is-filled .up-txt{color:var(--ink);}

/* Salary track with exactly TWO stops (e.g. Senior -> Lead): narrower + centered,
   two columns, and the connecting line aligned to the two dot centres (25%-75%). */
.page-template-vacancy-detail .sal-track.sal-2{max-width:660px;margin-left:auto;margin-right:auto;}
.page-template-vacancy-detail .sal-track.sal-2 .sal-amts,
.page-template-vacancy-detail .sal-track.sal-2 .sal-line,
.page-template-vacancy-detail .sal-track.sal-2 .sal-roles{grid-template-columns:repeat(2,1fr);}
.page-template-vacancy-detail .sal-track.sal-2 .sal-line::before{left:25%;right:25%;}

/* ===== Redesigned salary track: in-role growth (accent) + after-promotion (grey) =====
   Follows the "Vacature detail" artboard. Both segments are solid; the after-promotion
   half is greyed (var(--line-2)) rather than dashed. Desktop = .sal-track (.sal-segs
   labels, .ac in-role max, .next promotion max), mobile = .sal-rows grouped list. */
.page-template-vacancy-detail .sal-segs{position:relative;height:16px;margin-top:18px;}
.page-template-vacancy-detail .sal-segs .seg{position:absolute;top:0;transform:translateX(-50%);font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;}
.page-template-vacancy-detail .sal-segs .seg.now{left:33.333%;color:var(--accent);}
.page-template-vacancy-detail .sal-segs .seg.next{left:66.666%;color:var(--ink-3);}
.page-template-vacancy-detail .sal-amts span.next{color:var(--ink-3);font-weight:500;}
/* line: accent first segment (in-role), grey second segment (after promotion) */
.page-template-vacancy-detail .sal-line::before{left:16.666%;width:33.334%;right:auto;}
.page-template-vacancy-detail .sal-line::after{content:"";position:absolute;left:50%;width:33.334%;top:50%;transform:translateY(-50%);height:5px;border-radius:3px;background:var(--line-2);}
.page-template-vacancy-detail .sal-line .dot.cur{box-shadow:0 0 0 5px rgba(31,95,214,.16),0 0 18px rgba(31,95,214,.4);}
.page-template-vacancy-detail .sal-line .dot.end{border:3px solid var(--line-2);box-shadow:none;}
/* mobile grouped list: the full vertical timeline lives in the @media (max-width:768px) block above */

/* ===== contact form states (fc_ats contact handler) ===== */
.fc-hp{position:absolute!important;left:-9999px!important;top:-9999px!important;width:1px;height:1px;overflow:hidden;}
.fc-form-alert{margin:0 0 2px;padding:11px 14px;border:1px solid #e4b4ad;background:#fcf0ee;color:#9a2d1c;border-radius:8px;font-size:13px;line-height:1.5;}
.fc-err-msg{display:block;margin-top:6px;font-family:var(--sans);font-size:12px;color:#c0392b;line-height:1.4;}
.pfc-form .pfcf.fc-err input,.pfc-form .pfcf.fc-err select,.pfc-form .pfcf.fc-err textarea,
.ct-form .ctf.fc-err input,.ct-form .ctf.fc-err select,.ct-form .ctf.fc-err textarea{border-color:#c0392b;background:#fdf6f5;}
.pfc-form .pfcf.fc-err input:focus,.ct-form .ctf.fc-err input:focus,
.pfc-form .pfcf.fc-err textarea:focus,.ct-form .ctf.fc-err textarea:focus{border-color:#c0392b;box-shadow:0 0 0 3px rgba(192,57,43,.12);}
.ct-form .ctf-consent.fc-err{color:#9a2d1c;}
.ct-form .ctf-consent.fc-err .cs-box{border-color:#c0392b;}
/* success panel replaces the form in the same panel grid cell */
.fc-form-success{background:#fff;padding:42px 44px;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;gap:14px;}
.fc-form-success .fc-fs-check{flex:none;width:46px;height:46px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;box-shadow:0 10px 24px -10px rgba(31,95,214,.7);}
.fc-form-success .fc-fs-check svg{width:22px;height:22px;stroke:#fff;stroke-width:3;fill:none;stroke-linecap:round;stroke-linejoin:round;}
.fc-form-success h4{font-size:22px;letter-spacing:-.02em;line-height:1.15;margin:0;}
.fc-form-success p{font-size:14.5px;color:var(--ink-2);line-height:1.6;margin:0;max-width:42ch;}
@media (max-width:640px){.fc-form-success{padding:32px 24px;}}

/* ===== vacatures: location filter + focused-function view ===== */
.page-slug-vacatures .vac-filterbar{display:flex;flex-direction:column;gap:12px;margin-bottom:30px;}
.page-slug-vacatures .vac-filterbar .vac-filters{margin-bottom:0;}
.page-slug-vacatures .vac-filters-loc{align-items:center;}
.page-slug-vacatures .vac-flabel{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);margin-right:4px;}
.page-slug-vacatures .vac-card.hide{display:none;}
.page-slug-vacatures .vac-back{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);text-decoration:none;transition:color .2s ease;}
.page-slug-vacatures .vac-back:hover{color:var(--accent);}
@media (max-width:768px){
  .page-slug-vacatures .vac-filterbar{gap:9px;margin-bottom:20px;}
  .page-slug-vacatures .vac-flabel{width:100%;margin-bottom:-4px;}
}

/* ===== vacatures: function context bar + location dropdown + new-location ===== */
.page-slug-vacatures .vac-locwrap{display:inline-flex;align-items:center;gap:8px;}
.page-slug-vacatures .vac-locsel{font-family:var(--mono);font-size:11px;letter-spacing:.04em;text-transform:uppercase;padding:9px 32px 9px 15px;border-radius:999px;border:1px solid var(--line-2);color:var(--ink);background:#fff url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="10" height="6" viewBox="0 0 10 6"><path d="M1 1l4 4 4-4" stroke="%23667085" fill="none" stroke-width="1.5" stroke-linecap="round"/></svg>') no-repeat right 13px center;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;transition:border-color .2s ease;}
.page-slug-vacatures .vac-locsel:hover{border-color:var(--ink-3);}
.page-slug-vacatures .vac-locsel:focus{outline:none;border-color:var(--accent);}

.page-slug-vacatures .vac-context{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin:-6px 0 26px;padding:13px 18px;border-radius:12px;background:linear-gradient(165deg,#f3f7ff 0%,#e8eef9 100%);border:1px solid rgba(31,95,214,.25);}
.page-slug-vacatures .vac-context.hide{display:none;}
.page-slug-vacatures .vac-context .vc-ctx-txt{font-size:14px;color:var(--ink);}
.page-slug-vacatures .vac-context .vc-ctx-role{font-weight:600;}
.page-slug-vacatures .vac-context .vc-ctx-sep{color:var(--ink-3);margin:0 3px;}
.page-slug-vacatures .vac-context .vc-ctx-clear{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--accent);background:#fff;border:1px solid rgba(31,95,214,.3);border-radius:999px;padding:7px 14px;cursor:pointer;white-space:nowrap;transition:background .2s ease,color .2s ease,border-color .2s ease;}
.page-slug-vacatures .vac-context .vc-ctx-clear:hover{background:var(--accent);color:#fff;border-color:var(--accent);}
.page-slug-vacatures .vac-context .vc-ctx-x{font-size:12px;}

.page-slug-vacatures .vac-card .vc-loc-new{color:var(--accent);}
.page-slug-vacatures .vac-card .vc-loc .vc-pin{font-size:8px;vertical-align:middle;}
.page-slug-vacatures .vac-card .vc-newloc{align-self:flex-start;font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);background:rgba(31,95,214,.1);border-radius:999px;padding:2px 8px;margin-top:-3px;}

@media (max-width:768px){
  .page-slug-vacatures .vac-locwrap{width:100%;}
  .page-slug-vacatures .vac-locsel{flex:1;}
  .page-slug-vacatures .vac-context{margin-bottom:18px;padding:10px 14px;}
  .page-slug-vacatures .vac-context .vc-ctx-txt{font-size:13px;}
  .page-slug-vacatures .vac-context .vc-ctx-clear{font-size:10px;padding:6px 11px;}
}

/* ===== vacatures: location tag plain black (all locations existing) ===== */
.page-slug-vacatures .vac-card .vc-loc{color:var(--ink);}
.page-slug-vacatures .vac-card .vc-loc-new{color:var(--ink);}
.page-slug-vacatures .vac-card .vc-newloc{display:none;}

/* ===== vacatures: function + category + location filter rows ===== */
.page-slug-vacatures .vac-filterrow{display:flex;align-items:center;justify-content:space-between;gap:14px 18px;flex-wrap:wrap;width:100%;}
.page-slug-vacatures .vac-filterrow .vac-locwrap{margin-left:auto;}
.page-slug-vacatures .vac-filterbar .vac-filters{align-items:center;}
@media (max-width:768px){
  .page-slug-vacatures .vac-filterrow{gap:9px;}
  .page-slug-vacatures .vac-filterrow .vac-locwrap{margin-left:0;}
}

/* ===== vacature-detail: salary fine-print (excl. toeslagen/overwerk/reiskosten) ===== */
.page-template-vacancy-detail .sal-note{margin-top:18px;font-size:12.5px;line-height:1.6;color:var(--ink-3);}
/* fc-fix-mobile-en-flag: the mobile slide-in switcher uses class="en" (no .fl),
   so the original .m-flag2 .en rule had no background and the EN flag was blank.
   Restore the Union Jack (same SVG as .fl.en). */
.m-flag2 .en{background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 60 30'%3E%3Crect width='60' height='30' fill='%23012169'/%3E%3Cpath d='M0,0 L60,30 M60,0 L0,30' stroke='%23fff' stroke-width='6'/%3E%3Cpath d='M0,0 L60,30 M60,0 L0,30' stroke='%23C8102E' stroke-width='4'/%3E%3Cpath d='M30,0 V30 M0,15 H60' stroke='%23fff' stroke-width='10'/%3E%3Cpath d='M30,0 V30 M0,15 H60' stroke='%23C8102E' stroke-width='6'/%3E%3C/svg%3E") center/100% 100% no-repeat;}

/* ===== Services & Producten overzicht · mobile (390 artboard) [fc-services-mobile-v1] =====
   Desktop bento (.svc/.tile, .prodcards/.pc) is the .ab-d design and stays as is.
   Mobile mirrors the .ab-m .m-sp-card layout. */
.page-slug-services .m-sp-grid{display:none;}
@media (max-width:768px){
  /* hero */
  .page-slug-services .sp-hero{padding:94px 0 var(--sec-y);}
  .page-slug-services .sp-hero h1{font-size:31px;line-height:1.06;letter-spacing:-.035em;margin-top:13px;}
  .page-slug-services .sp-hero .lead{font-size:14.5px;line-height:1.55;margin-top:14px;}
  .page-slug-services .sp-hero .jump{gap:8px;margin-top:20px;}
  .page-slug-services .sp-hero .jump a{padding:9px 14px;font-size:13px;gap:7px;}
  .page-slug-services .sp-hero .jump a .n{font-size:10px;}

  /* section shell + heading */
  .page-slug-services .sp-sec{padding:var(--sec-y) 0;}
  .page-slug-services .sp-sec .sechead{flex-direction:column;align-items:flex-start;gap:10px;margin-bottom:0;}
  .page-slug-services .sp-sec .sechead .btn{display:none;}
  .page-slug-services .sp-sec h2{font-size:24px;letter-spacing:-.03em;margin-top:12px;}
  .page-slug-services .sp-sec .intro{font-size:13.5px;line-height:1.55;margin-top:10px;}
  .page-slug-services .secnum .num{width:22px;height:22px;border-radius:6px;font-size:10px;}

  /* services: swap desktop bento for uniform photo-cards */
  .page-slug-services .svc{display:none;}
  .page-slug-services .m-sp-grid{display:flex;flex-direction:column;gap:13px;margin-top:20px;}
  .page-slug-services .m-sp-card{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--paper);text-decoration:none;color:inherit;display:block;}
  .page-slug-services .m-sp-card .frame{position:relative;height:150px;overflow:hidden;background:#dcd8cf;}
  .page-slug-services .m-sp-card .frame::after{content:"";position:absolute;inset:0;background:linear-gradient(150deg,transparent 46%,rgba(31,95,214,.2));z-index:2;pointer-events:none;}
  .page-slug-services .m-sp-card .body{padding:15px 16px 17px;}
  .page-slug-services .m-sp-card .hd{display:flex;align-items:center;gap:9px;}
  .page-slug-services .m-sp-card .ix{font-family:var(--mono);font-size:9.5px;letter-spacing:.08em;color:var(--ink-3);}
  .page-slug-services .m-sp-card .chip{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:linear-gradient(120deg,#1f5fd6,#5b7bff);border-radius:999px;padding:3px 8px;}
  .page-slug-services .m-sp-card .chip .d{width:5px;height:5px;border-radius:50%;background:#fff;}
  .page-slug-services .m-sp-card .chip.kern,.page-slug-services .m-sp-card .chip.core{background:linear-gradient(120deg,#2b313c,#4c5563);}
  .page-slug-services .m-sp-card .chip.soft{background:none;color:var(--ink-3);border:1px solid var(--line-2);}
  .page-slug-services .m-sp-card .chip.soft .d{background:var(--ink-3);}
  .page-slug-services .m-sp-card h3{font-size:18px;letter-spacing:-.02em;margin-top:9px;}
  .page-slug-services .m-sp-card p{margin-top:8px;color:var(--ink-2);line-height:1.5;font-size:13px;}
  .page-slug-services .m-sp-card .tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:11px;}
  .page-slug-services .m-sp-card .tags span{font-family:var(--mono);font-size:9px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-2);border:1px solid var(--line-2);border-radius:4px;padding:3px 7px;}
  .page-slug-services .m-sp-card .go{margin-top:13px;font-size:12px;font-weight:500;color:var(--accent);display:inline-flex;align-items:center;gap:6px;}

  /* products: separate rounded cards (match .m-sp-card), not the joined desktop grid */
  .page-slug-services .prodcards{display:flex;flex-direction:column;gap:13px;background:transparent;border-radius:0;box-shadow:none;overflow:visible;margin-top:20px;}
  .page-slug-services .pc{display:block;grid-template-columns:1fr;min-height:0;border:1px solid var(--line);border-radius:12px;background:var(--paper);overflow:hidden;}
  .page-slug-services .pc .frame{height:150px;}
  .page-slug-services .pc .body{padding:15px 16px 17px;}
  .page-slug-services .pc h3{font-size:18px;}
  .page-slug-services .pc p{font-size:13px;max-width:none;}
  .page-slug-services .pc .spec{font-size:9.5px;margin-top:9px;}
  .page-slug-services .pc .go{margin-top:13px;font-size:12px;padding-top:0;}

  /* CTA: reflow the card (desktop flex-row -> stacked, full-width button) */
  .page-slug-services .sp-cta{padding:var(--sec-y) 0;}
  .page-slug-services .sp-cta .card{display:block;padding:26px 22px;border-radius:16px;gap:0;}
  .page-slug-services .sp-cta .card .l{display:block;}
  .page-slug-services .sp-cta h2{font-size:22px;margin-top:12px;max-width:none;}
  .page-slug-services .sp-cta p{font-size:13px;margin-top:10px;max-width:none;}
  .page-slug-services .sp-cta .acts{display:block;margin-top:16px;}
  .page-slug-services .sp-cta .acts .btn{width:100%;justify-content:center;}
}
/* ===== end fc-services-mobile-v1 ===== */

/* ===== beeldmerk before the wordmark in the menu brand links [fc-beeldmerk-v1] =====
   Empty .bmark <span> recoloured via CSS mask (white webp = mask, background =
   colour) so it tracks the bar like the wordmark. Sizes per the design artboard
   (.ab-d 36x15, .ab-m 31x13). Mirrors the .brand b colour selectors incl.
   nav-light. NOT used in the footer. */
.brand .bmark{width:36px;height:15px;display:block;align-self:center;flex:none;background:var(--ink);-webkit-mask:url("../img/first-case-beeldmerk.webp?v=2") center/contain no-repeat;mask:url("../img/first-case-beeldmerk.webp?v=2") center/contain no-repeat;}
.m-bar .brand .bmark,.m-menu-bar .brand .bmark{width:31px;height:13px;}

/* dark bars -> white mark */
.topbar.over .brand .bmark{background:#fff;}
.m-topbar.over .m-bar .brand .bmark{background:#fff;}
.m-menu .m-menu-bar .brand .bmark{background:#fff;}

/* nav-light: the "over" bars are actually light glass -> back to ink (mirrors .brand b) */
body.nav-light .topbar.over .brand .bmark{background:var(--ink);}
body.nav-light .m-topbar.over .m-bar .brand .bmark{background:var(--ink);}
/* ===== end fc-beeldmerk-v1 ===== */

/* ===== vacatures: search + three dropdowns + context (updated design) [fc-vac-search-v1] ===== */
.page-slug-vacatures .vac-filterbar{display:flex;flex-direction:row;align-items:center;gap:14px;margin-bottom:14px;flex-wrap:wrap;}
.page-slug-vacatures .vac-search{position:relative;display:flex;align-items:center;flex:1;min-width:260px;}
.page-slug-vacatures .vac-search svg{position:absolute;left:16px;width:15px;height:15px;color:var(--ink-3);pointer-events:none;}
.page-slug-vacatures .vac-search .vac-q{width:100%;font-family:var(--sans);font-size:14px;color:var(--ink);background:#fff;border:1px solid var(--line-2);border-radius:999px;padding:11px 16px 11px 41px;transition:border-color .15s ease,box-shadow .15s ease;}
.page-slug-vacatures .vac-search .vac-q::placeholder{color:var(--ink-3);}
.page-slug-vacatures .vac-search .vac-q:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(31,95,214,.18);}
.page-slug-vacatures .vac-search .vac-q::-webkit-search-cancel-button{cursor:pointer;}
.page-slug-vacatures .vac-selects{display:flex;gap:10px;flex:none;}
.page-slug-vacatures .vac-selwrap{position:relative;display:inline-flex;align-items:center;}
.page-slug-vacatures .vac-sel{appearance:none;-webkit-appearance:none;font-family:var(--mono);font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink);background:#fff;border:1px solid var(--line-2);border-radius:999px;padding:11px 34px 11px 15px;cursor:pointer;transition:border-color .15s ease;}
.page-slug-vacatures .vac-sel:hover{border-color:var(--ink-3);}
.page-slug-vacatures .vac-sel:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(31,95,214,.18);}
.page-slug-vacatures .vac-sel.on{background:var(--ink);color:#fff;border-color:var(--ink);}
.page-slug-vacatures .vac-selwrap .car{position:absolute;right:14px;top:50%;transform:translateY(-50%);pointer-events:none;font-size:9px;color:var(--ink-3);}
.page-slug-vacatures .vac-selwrap.on .car{color:rgba(255,255,255,.7);}
.page-slug-vacatures .vac-noresults{display:none;padding:26px 0 8px;color:var(--ink-2);font-size:15px;}
.page-slug-vacatures .vac-noresults.show{display:block;}
.page-slug-vacatures .vac-noresults a{color:var(--accent);text-decoration:underline;text-underline-offset:2px;}
.page-slug-vacatures .vac-context{display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:16px;margin:0 0 24px;padding:14px 18px;border:1px solid rgba(31,95,214,.28);background:linear-gradient(165deg,rgba(31,95,214,.07),rgba(31,95,214,.02));border-radius:12px;}
.page-slug-vacatures .vac-context[hidden]{display:none;}
.page-slug-vacatures .vac-context .vc-ctx-txt{font-size:14px;color:var(--ink-2);}
.page-slug-vacatures .vac-context .vc-ctx-txt b{color:var(--ink);font-weight:600;}
.page-slug-vacatures .vac-context .vc-ctx-txt .vc-ctx-count{font-family:var(--mono);color:var(--accent);font-weight:500;}
.page-slug-vacatures .vac-context .vc-ctx-clear{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);background:none;border:0;cursor:pointer;white-space:nowrap;padding:4px 0;}
.page-slug-vacatures .vac-context .vc-ctx-clear:hover{color:var(--accent-ink);}
@media (max-width:768px){
  .page-slug-vacatures .vac-filterbar{display:flex;flex-direction:column;gap:9px;margin-bottom:12px;}
  .page-slug-vacatures .vac-search{position:relative;display:flex;align-items:center;}
  .page-slug-vacatures .vac-search svg{left:13px;width:14px;height:14px;}
  .page-slug-vacatures .vac-search .vac-q{font-size:14px;padding:10px 14px 10px 36px;}
  .page-slug-vacatures .vac-selects{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
  .page-slug-vacatures .vac-selwrap{position:relative;display:flex;}
  .page-slug-vacatures .vac-selwrap:first-child{grid-column:1 / -1;}
  .page-slug-vacatures .vac-sel{width:100%;font-size:10px;padding:10px 28px 10px 13px;}
  .page-slug-vacatures .vac-selwrap .car{right:12px;font-size:8px;}
  .page-slug-vacatures .vac-noresults{padding:18px 0 4px;font-size:14px;}
  .page-slug-vacatures .vac-context{gap:12px;margin-bottom:18px;padding:12px 14px;border-radius:11px;}
  .page-slug-vacatures .vac-context .vc-ctx-txt{font-size:12.5px;line-height:1.4;}
  .page-slug-vacatures .vac-context .vc-ctx-clear{gap:6px;font-size:10px;flex:none;}
}
/* ===== end fc-vac-search-v1 ===== */

/* ===== fc-nav-dropdown-v1 · Services/Producten mega-dropdowns (desktop hover) + mobile accordion ===== */
.topbar.over .navitem{position:relative;}
.topbar.over .navitem .top{display:inline-flex;align-items:center;gap:7px;padding:9px 15px;border-radius:999px;cursor:pointer;white-space:nowrap;color:rgba(255,255,255,.82);transition:background .2s ease,color .2s ease;}
.topbar.over .navitem .caret{font-size:9px;color:rgba(255,255,255,.6);transition:transform .2s ease;}
.topbar.over .navitem:hover .top,.topbar.over .navitem:focus-within .top{background:rgba(255,255,255,.12);color:#fff;}
.topbar.over .navitem:hover .caret,.topbar.over .navitem:focus-within .caret{transform:rotate(180deg);}
.topbar.over .navitem .panel{position:absolute;top:100%;padding-top:12px;left:0;opacity:0;visibility:hidden;transform:translateY(-6px);transition:opacity .18s ease,transform .18s ease,visibility .18s;z-index:30;}
.topbar.over .navitem:hover .panel,.topbar.over .navitem:focus-within .panel{opacity:1;visibility:visible;transform:translateY(0);}
.topbar.over .panel .sheet{min-width:420px;background:rgba(20,24,32,.97);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.12);border-radius:16px;box-shadow:0 40px 80px -40px rgba(0,0,0,.7);padding:10px;}
.topbar.over .panel .di{display:flex;flex-direction:column;padding:12px 13px;border-radius:11px;color:rgba(255,255,255,.9);}
.topbar.over .panel .di:hover{background:rgba(127,176,255,.14);}
.topbar.over .panel .di .dirow{display:flex;align-items:center;gap:11px;}
.topbar.over .panel .di .ic{width:30px;height:30px;flex:none;border-radius:8px;background:rgba(127,176,255,.14);display:flex;align-items:center;justify-content:center;color:var(--svc,#7fb0ff);font-family:var(--mono);font-size:11px;}
.topbar.over .panel .di .tt{font-size:14px;font-weight:500;}
.topbar.over .panel .di .ds{font-size:12.5px;color:rgba(255,255,255,.52);margin-top:3px;margin-left:41px;line-height:1.5;}
/* light nav variant */
body.nav-light .topbar.over .navitem .top{color:var(--ink-2);}
body.nav-light .topbar.over .navitem .caret{color:var(--ink-3);}
body.nav-light .topbar.over .navitem:hover .top,body.nav-light .topbar.over .navitem:focus-within .top{background:rgba(0,0,0,.05);color:var(--ink);}
body.nav-light .topbar.over .panel .sheet{background:rgba(255,255,255,.98);border-color:var(--line);box-shadow:0 40px 80px -40px rgba(20,25,40,.4);}
body.nav-light .topbar.over .panel .di{color:var(--ink);}
body.nav-light .topbar.over .panel .di:hover{background:rgba(31,95,214,.07);}
body.nav-light .topbar.over .panel .di .ic{background:rgba(31,95,214,.1);color:var(--svc-ink,var(--accent));}
body.nav-light .topbar.over .panel .di .tt{color:var(--ink);}
body.nav-light .topbar.over .panel .di .ds{color:var(--ink-3);}
/* mobile slide-in menu · accordion (always dark) */
.m-menu nav .ln{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 0;border-bottom:1px solid rgba(255,255,255,.1);color:#fff;cursor:pointer;}
.m-menu nav .ln .lbl{font-size:25px;letter-spacing:-.025em;font-weight:500;}
.m-menu nav .ln .pm{font-size:22px;line-height:1;color:rgba(255,255,255,.5);transition:transform .2s ease;}
.m-menu nav .ln.on .pm{transform:rotate(45deg);color:#9cc0ff;}
.m-menu nav .m-sub{overflow:hidden;max-height:0;transition:max-height .3s ease;}
.m-menu nav .m-sub.open{max-height:560px;}
.m-menu nav .m-sub .inner{display:flex;flex-direction:column;padding:4px 0 14px;}
.m-menu nav .m-sub .si{display:flex;align-items:center;gap:13px;padding:11px 0;border-bottom:0;color:rgba(255,255,255,.82);}
.m-menu nav .m-sub .si .ic{width:28px;height:28px;flex:none;border-radius:7px;background:rgba(127,176,255,.14);display:flex;align-items:center;justify-content:center;color:var(--svc,#7fb0ff);font-family:var(--mono);font-size:10px;}
.m-menu nav .m-sub .si .tt{font-size:16px;}
/* ===== /fc-nav-dropdown-v1 ===== */

/* ===== fc-illus-v1 · "client anonymous / illustrative" disclosure tag on case images ===== */
.fc-illus{position:absolute;left:10px;bottom:10px;z-index:3;max-width:calc(100% - 20px);font-family:var(--mono);font-size:10px;letter-spacing:.01em;line-height:1.25;color:#fff;background:rgba(12,16,24,.7);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);border:1px solid rgba(255,255,255,.14);border-radius:7px;padding:5px 9px;pointer-events:none;}
/* too small to be legible on the 78px compact thumbs -> hide there */
.post-type-archive-fc_case .m-cs-card .thumb .fc-illus,
.single-fc_case .m-case-rel .thumb .fc-illus{display:none;}
/* ===== /fc-illus-v1 ===== */
/* ===== fc-tdraw-v1 · isometric technical case drawings (replace phase photos) ===== */
/* Dark drawing board on the phase image slot. SVG classes are scoped under .tdraw
   so they do not collide with the site's own .grid / .acc layout classes. */
.single-fc_case .cb .img.tdraw,
.single-fc_case .m-cb .img.tdraw{background:#10141b;border-color:#1e2733;}
.single-fc_case .cb .img.tdraw{aspect-ratio:3/2;min-height:0;align-self:center;}
.single-fc_case .cb .img.tdraw::after{display:none;}
.single-fc_case .m-cb .img.tdraw{aspect-ratio:3/2;height:auto;}
.tdraw{
  --d-bg:#10141b;--d-grid:rgba(150,180,230,.10);
  --d-line:rgba(212,226,247,.9);--d-line-2:rgba(160,185,225,.45);
  --d-dim:rgba(160,185,225,.5);--d-dim-txt:rgba(190,210,240,.85);
  --d-txt:rgba(212,226,247,.88);--d-face:rgba(110,150,230,.10);
  --d-accent:#74a8ff;--d-accent-f:#74a8ff;
}
.tdraw svg{display:block;width:100%;height:100%;}
.tdraw .grid{stroke:var(--d-grid);stroke-width:.6;fill:none;}
.tdraw .l{fill:none;stroke:var(--d-line);stroke-width:1.4;stroke-linecap:round;stroke-linejoin:round;}
.tdraw .l2{fill:none;stroke:var(--d-line-2);stroke-width:1;stroke-linecap:round;stroke-linejoin:round;}
.tdraw .hid{fill:none;stroke:var(--d-line-2);stroke-width:1;stroke-dasharray:4 4;}
.tdraw .dim{fill:none;stroke:var(--d-dim);stroke-width:.8;}
.tdraw .face{fill:var(--d-face);stroke:none;}
.tdraw .acc{fill:none;stroke:var(--d-accent);stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;}
.tdraw .accf{fill:var(--d-accent-f);stroke:none;}
.tdraw .accdash{fill:none;stroke:var(--d-accent);stroke-width:1.5;stroke-dasharray:6 5;}
.tdraw .dot{fill:var(--d-line);}
.tdraw text{fill:var(--d-txt);font-family:var(--mono),"Geist Mono",monospace;}
.tdraw .t-acc{fill:var(--d-accent);}
.tdraw .t-dim{fill:var(--d-dim-txt);}
.tdraw .tb-box,.tdraw .tb-line{stroke:var(--d-line-2);stroke-width:.8;fill:none;}
/* ===== /fc-tdraw-v1 ===== */
/* ===== fc-tdraw-feat-v1 · iso drawing on the cases-overview featured hero ===== */
.post-type-archive-fc_case .cs-feat .frame.tdraw,
.post-type-archive-fc_case .m-cs-feat .frame.tdraw{background:#10141b;border:1px solid #1e2733;}
.post-type-archive-fc_case .cs-feat .frame.tdraw{aspect-ratio:3/2;min-height:0;align-self:center;}
.post-type-archive-fc_case .cs-feat .frame.tdraw::after{display:none;}
.post-type-archive-fc_case .m-cs-feat .frame.tdraw{height:auto;aspect-ratio:3/2;}
.post-type-archive-fc_case .m-cs-feat .frame.tdraw::after{display:none;}
/* ===== /fc-tdraw-feat-v1 ===== */
/* ===== fc-tdraw-card-v1 · iso drawing as the image on ALL case cards ===== */
/* Wide cards (cases-overview grid + case-detail "Andere cases"): dark 3:2 board,
   drawing edge-to-edge, photo gradient overlay hidden. */
.cs-card .frame.tdraw,
.single-fc_case .case-rel .frame.tdraw{background:#10141b;border-bottom:1px solid #1e2733;height:auto;aspect-ratio:3/2;}
.cs-card .frame.tdraw::after,
.single-fc_case .case-rel .frame.tdraw::after{display:none;}
/* Compact 78px square thumbs (mobile grid + mobile "Andere cases"): dark board,
   drawing letterboxed (3:2 meets the square, dark bands blend with the board). */
.post-type-archive-fc_case .m-cs-card .thumb.tdraw,
.single-fc_case .m-case-rel .thumb.tdraw{background:#10141b;border:1px solid #1e2733;}
.post-type-archive-fc_case .m-cs-card .thumb.tdraw::after,
.single-fc_case .m-case-rel .thumb.tdraw::after{display:none;}
/* homepage cases block (.case) + service/product-detail related cards (.ccard) */
.cases .case .frame.tdraw{background:#10141b;height:auto;aspect-ratio:3/2;}
.cases .case .frame.tdraw::after{display:none;}
.page-template-service-detail .ccard .frame.tdraw{background:#10141b;border-bottom:1px solid #1e2733;height:auto;aspect-ratio:3/2;}
.page-template-service-detail .ccard .frame.tdraw::after{display:none;}
/* ===== /fc-tdraw-card-v1 ===== */
/* ===== fc-cardgrid · uniform "case-card" style for any card grid ===== */
/* Reusable modifier: add class "fc-cardgrid" to a card-grid container and its
   direct <a> cards adopt the case-card look (white, rounded, spaced apart,
   subtle hover-lift). Each grid keeps its own columns/proportions. Applied so
   far: homepage services grid (.svc.fc-cardgrid). Roll out per section on
   request. NB this neutralises a component's own flush-panel / gradient-tile
   styling (e.g. the .svc/.tile gradients) by being later in the cascade. */
.fc-cardgrid{border:0;border-radius:0;background:transparent;box-shadow:none;overflow:visible;gap:24px;}
.fc-cardgrid > a{border:1px solid var(--line);border-radius:14px;background:var(--paper);box-shadow:0 14px 30px -26px rgba(30,42,64,.5);transition:box-shadow .3s ease,transform .3s ease;}
.fc-cardgrid > a:hover{transform:translateY(-3px);box-shadow:0 30px 60px -34px rgba(30,42,64,.55);background:var(--paper);}
.fc-cardgrid .frame{border-radius:10px;box-shadow:none;}
.fc-cardgrid .frame.tdraw{background:#10141b;border:1px solid #1e2733;}
.fc-cardgrid .frame.tdraw::after{display:none;}
/* homepage services: UPS & Monitoring (row 1) exactly 1.5x the height of the
   Maintenance/Loadbank/Deep-Cleaning cards (row 2); UPS illustration frame flush
   to the card edges. Heights fixed so the (portrait-cropped) SVG fills the frame
   instead of driving its height. Desktop only; mobile stacks. */
@media (min-width:769px){
  .fc-cardgrid .t-mnt,.fc-cardgrid .t-load,.fc-cardgrid .t-clean{height:220px;min-height:0;}
  .fc-cardgrid .t-ups,.fc-cardgrid .t-mon{height:330px;min-height:0;}
  .fc-cardgrid .t-ups{padding:0;gap:0;overflow:hidden;}
  .fc-cardgrid .t-ups .colL{padding:30px;}
  .fc-cardgrid .t-ups .frame{border-radius:0;height:100%;min-height:0;}
  .fc-cardgrid .t-ups .frame.tdraw{border:0;border-left:1px solid #1e2733;}
}
@media (max-width:768px){
  .fc-cardgrid .t-ups .frame.tdraw{height:200px;}
}
/* homepage UPS tile: REAL 3D orbit rendered on <canvas> by ups3d.js. The frame
   holds the static iso SVG as a fallback; the script adds .ups3d-on + a canvas
   and hides the SVG. Scoped to this tile only. */
.fc-cardgrid .t-ups .frame.tdraw{overflow:hidden;position:relative;}
.fc-cardgrid .t-ups .frame.tdraw .ups3d-canvas{position:absolute;inset:0;width:100%;height:100%;display:block;}
.fc-cardgrid .t-ups .frame.tdraw.ups3d-on svg{display:none;}
/* homepage beliefs (03 "Waar wij in geloven"): fc card style on the .p cards (no images, no links) */
.prin.fc-cardgrid .p{border:1px solid var(--line);border-radius:14px;background:var(--paper);box-shadow:0 14px 30px -26px rgba(30,42,64,.5);transition:box-shadow .3s ease,transform .3s ease;}
.prin.fc-cardgrid .p:hover{transform:translateY(-3px);box-shadow:0 30px 60px -34px rgba(30,42,64,.55);background:var(--paper);}
/* over-ons: principes (.vals) + certificeringen (.certs) -> fc card style
   (page-scoped to outweigh the existing .page-slug-over-ons rules) */
.page-slug-over-ons .vals.fc-cardgrid{gap:24px;background:transparent;border-radius:0;overflow:visible;box-shadow:none;}
.page-slug-over-ons .vals.fc-cardgrid .v{border:1px solid var(--line);border-radius:14px;background:var(--paper);box-shadow:0 14px 30px -26px rgba(30,42,64,.5);transition:box-shadow .3s ease,transform .3s ease;}
.page-slug-over-ons .vals.fc-cardgrid .v:hover{transform:translateY(-3px);box-shadow:0 30px 60px -34px rgba(30,42,64,.55);background:var(--paper);}
.page-slug-over-ons .certs.fc-cardgrid{gap:24px;}
.page-slug-over-ons .certs.fc-cardgrid .c{background:var(--paper);box-shadow:0 14px 30px -26px rgba(30,42,64,.5);transition:box-shadow .3s ease,transform .3s ease;}
.page-slug-over-ons .certs.fc-cardgrid .c:hover{transform:translateY(-3px);box-shadow:0 30px 60px -34px rgba(30,42,64,.55);background:var(--paper);}
/* werken-bij: week (.week/.day), academy programs (.programs/.prog), the deal
   (.deal/.deal-col), and paths (.paths/.pth) -> fc card style. Page-scoped to
   outweigh the existing .page-slug-werken-bij flush-panel rules. */
.page-slug-werken-bij .week.fc-cardgrid,
.page-slug-werken-bij .programs.fc-cardgrid,
.page-slug-werken-bij .deal.fc-cardgrid,
.page-slug-werken-bij .paths.fc-cardgrid{gap:24px;background:transparent;border-radius:0;overflow:visible;box-shadow:none;}
.page-slug-werken-bij .week.fc-cardgrid .day,
.page-slug-werken-bij .programs.fc-cardgrid .prog,
.page-slug-werken-bij .deal.fc-cardgrid .deal-col,
.page-slug-werken-bij .paths.fc-cardgrid .pth{border:1px solid var(--line);border-radius:14px;background:var(--paper);box-shadow:0 14px 30px -26px rgba(30,42,64,.5);transition:box-shadow .3s ease,transform .3s ease;}
.page-slug-werken-bij .week.fc-cardgrid .day:hover,
.page-slug-werken-bij .programs.fc-cardgrid .prog:hover,
.page-slug-werken-bij .deal.fc-cardgrid .deal-col:hover,
.page-slug-werken-bij .paths.fc-cardgrid .pth:hover{transform:translateY(-3px);box-shadow:0 30px 60px -34px rgba(30,42,64,.55);background:var(--paper);}
/* vacancy detail: section eyebrows aligned to the homepage .secnum numbered-badge style (was .dlabel) */
.page-template-vacancy-detail .secnum{margin-bottom:var(--eyb-gap);}
.page-template-vacancy-detail .vd-sechead .secnum{margin-bottom:0;}
/* vacancy detail: "05 zo werkt solliciteren" steps -> fc card style */
.page-template-vacancy-detail .vd-proces.fc-cardgrid{gap:24px;background:transparent;border-radius:0;overflow:visible;box-shadow:none;}
.page-template-vacancy-detail .vd-proces.fc-cardgrid .vd-step{border:1px solid var(--line);border-radius:14px;background:var(--paper);box-shadow:0 14px 30px -26px rgba(30,42,64,.5);transition:box-shadow .3s ease,transform .3s ease;}
.page-template-vacancy-detail .vd-proces.fc-cardgrid .vd-step.trial{background:var(--paper);}
.page-template-vacancy-detail .vd-proces.fc-cardgrid .vd-step:hover{transform:translateY(-3px);box-shadow:0 30px 60px -34px rgba(30,42,64,.55);background:var(--paper);}
/* homepage products: three large VERTICAL fc-cards (image on top, body below) */
.prodcards.fc-cardgrid{grid-template-columns:repeat(3,1fr);}
.prodcards.fc-cardgrid .pc{display:flex;flex-direction:column;min-height:0;}
.prodcards.fc-cardgrid .pc .frame{height:210px;}
@media(max-width:768px){
  .prodcards.fc-cardgrid{grid-template-columns:1fr;}
  .prodcards.fc-cardgrid .pc .frame{height:150px;}
}
/* service detail "Onze aanpak" (.appr) — separate fc-cardgrid cards instead of the flush panel (containment page) */
.page-template-service-detail .appr.fc-cardgrid{gap:24px;background:transparent;border:0;border-radius:0;overflow:visible;box-shadow:none;}
.page-template-service-detail .appr.fc-cardgrid .c{border:1px solid var(--line);border-radius:14px;background:var(--paper);box-shadow:0 14px 30px -26px rgba(30,42,64,.5);transition:box-shadow .3s ease,transform .3s ease;}
.page-template-service-detail .appr.fc-cardgrid .c:hover{transform:translateY(-3px);box-shadow:0 30px 60px -34px rgba(30,42,64,.55);background:var(--paper);}
/* ===== /fc-cardgrid ===== */

/* fc:card-index-numbers uniform */
.prin .p .ix,
.m-prin .ix,
.page-template-service-detail .appr .c .n,
.single-fc_case .appr .c .n,
.page-slug-over-ons .paths .pth .n,
.page-slug-werken-bij .paths .pth .n,
.page-slug-over-ons .vals .v .vn,
.page-slug-werken-bij .week .day .d,
.page-slug-werken-bij .prog .bn,
.page-slug-over-ons .vd-step .n,
.page-slug-over-ons .vd-step.trial .n,
.page-template-vacancy-detail .vd-step .n,
.page-template-vacancy-detail .vd-step.trial .n{color:transparent;-webkit-text-stroke:1px var(--accent);transition:color .3s ease,-webkit-text-stroke .3s ease,text-shadow .3s ease;}
.prin .p:hover .ix,
.page-template-service-detail .appr .c:hover .n,
.single-fc_case .appr .c:hover .n,
.page-slug-over-ons .paths .pth:hover .n,
.page-slug-werken-bij .paths .pth:hover .n,
.page-slug-over-ons .vals .v:hover .vn,
.page-slug-werken-bij .week .day:hover .d,
.page-slug-werken-bij .prog:hover .bn,
.page-slug-over-ons .vd-step:hover .n,
.page-template-vacancy-detail .vd-step:hover .n{color:var(--accent);-webkit-text-stroke:0;text-shadow:0 0 22px rgba(31,95,214,.45);}

/* ===== fc-ct-redesign-v1 · Product Containment redesign: editorial overlap blocks + designer + render + uniform "meer" cards ===== */
/* --- editorial content blocks: side-by-side grid -> overlapping editorial card (desktop) --- */
.page-template-service-detail .ct-editorial .blocks{padding:var(--sec-y) 40px;}
.page-template-service-detail .ct-editorial .cb{display:block;position:relative;max-width:1360px;margin-left:auto;margin-right:auto;}
.page-template-service-detail .ct-editorial .cb + .cb{margin-top:96px;}
.page-template-service-detail .ct-editorial .cb .img{height:484px;min-height:484px;border-radius:14px;}
.page-template-service-detail .ct-editorial .cb .txt{position:absolute;bottom:-30px;width:466px;background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:32px 34px;box-shadow:0 44px 88px -54px rgba(16,19,25,.55);z-index:3;}
.page-template-service-detail .ct-editorial .cb.normal .txt{left:46px;right:auto;}
.page-template-service-detail .ct-editorial .cb.flip .txt{right:46px;left:auto;}
.page-template-service-detail .ct-editorial .cb h3{font-size:42px;font-weight:600;letter-spacing:-.03em;line-height:1.04;margin:14px 0 14px;max-width:none;}
.page-template-service-detail .ct-editorial .cb p{font-size:14.5px;color:var(--ink-2);line-height:1.62;max-width:none;}
.page-template-service-detail .ct-editorial .cb .pts{margin-top:24px;border-top:0;}

/* --- "Ontwerp je eigen containment" designer block (NEW) --- */
.page-template-service-detail .designer{padding:var(--sec-y) 0;border-bottom:1px solid var(--line);background:radial-gradient(1100px 560px at 82% -16%,rgba(31,95,214,.08),transparent 70%);}
.page-template-service-detail .dz-grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:54px;align-items:center;background:#fff;border:1px solid var(--line-2);border-radius:22px;padding:48px;box-shadow:0 40px 90px -56px rgba(20,28,44,.4);}
.page-template-service-detail .dz-new{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:#fff;background:var(--accent);border-radius:999px;padding:5px 12px;margin-bottom:18px;box-shadow:0 6px 18px -6px rgba(31,95,214,.6);}
.page-template-service-detail .dz-new .nd{width:6px;height:6px;border-radius:50%;background:#fff;box-shadow:0 0 8px rgba(255,255,255,.9);}
.page-template-service-detail .dz-h{font-size:42px;font-weight:600;line-height:1.04;letter-spacing:-.03em;color:#16181d;}
.page-template-service-detail .dz-h em{font-style:normal;color:var(--accent);}
.page-template-service-detail .dz-lead{margin-top:18px;font-size:16px;line-height:1.6;color:var(--ink-2);max-width:46ch;}
.page-template-service-detail .dz-pts{list-style:none;margin:24px 0 0;padding:0;display:flex;flex-direction:column;gap:12px;}
.page-template-service-detail .dz-pts li{display:flex;align-items:baseline;gap:14px;font-size:15px;color:var(--ink);}
.page-template-service-detail .dz-pts .pn{font-family:var(--mono);font-size:11px;color:var(--accent);flex:none;}
.page-template-service-detail .dz-cta{display:flex;align-items:center;gap:18px;margin-top:30px;flex-wrap:wrap;}
.page-template-service-detail .dz-note{font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--ink-3);}
.page-template-service-detail .browser{border-radius:14px;overflow:hidden;background:#fff;border:1px solid var(--line-2);box-shadow:0 50px 100px -50px rgba(20,28,44,.55);}
.page-template-service-detail .browser .bchrome{display:flex;align-items:center;gap:8px;padding:13px 16px;background:linear-gradient(180deg,#f4f6f9,#e9edf2);border-bottom:1px solid var(--line);}
.page-template-service-detail .browser .bd{width:11px;height:11px;border-radius:50%;}
.page-template-service-detail .browser .bd.r{background:#ec6a5e;}
.page-template-service-detail .browser .bd.y{background:#f4bf4f;}
.page-template-service-detail .browser .bd.g{background:#61c554;}
.page-template-service-detail .browser .burl{margin-left:14px;flex:1;display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:8px;padding:7px 13px;font-family:var(--mono);font-size:12px;color:var(--ink-2);max-width:340px;}
.page-template-service-detail .browser .burl .lock{width:9px;height:8px;border:1.4px solid var(--ink-3);border-radius:2px;position:relative;flex:none;margin-top:-1px;}
.page-template-service-detail .browser .bscreen{position:relative;aspect-ratio:16/9;background:#0e1116;}
.page-template-service-detail .browser .bscreen video{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;}

/* --- full-bleed render video (NEW) --- */
.page-template-service-detail .render{padding:0;}
.page-template-service-detail .render>.wrap{padding:0;max-width:none;}
.page-template-service-detail .rd-card{border-radius:0;overflow:hidden;background:#0e1116;border:none;border-top:1px solid var(--line-2);border-bottom:1px solid var(--line-2);box-shadow:none;aspect-ratio:16/9;}
.page-template-service-detail .rd-card video{width:100%;height:100%;object-fit:cover;display:block;}

/* --- 04 "Meer van First Case" -> uniform standard cards (fc-cardgrid) --- */
.page-template-service-detail .other.fc-cardgrid{gap:24px;background:transparent;border:0;border-radius:0;overflow:visible;box-shadow:none;}
.page-template-service-detail .other.fc-cardgrid a{border:1px solid var(--line);border-radius:14px;background:var(--paper);box-shadow:0 14px 30px -26px rgba(30,42,64,.5);transition:box-shadow .3s ease,transform .3s ease,background .3s ease;}
.page-template-service-detail .other.fc-cardgrid a:hover{transform:translateY(-3px);box-shadow:0 30px 60px -34px rgba(30,42,64,.55);background:var(--paper);}

/* --- hero: design copy (long 3-line title) needs the design's constrained column + uncapped h1 wrap (scoped to containment via .ct-hero) --- */
.page-template-service-detail .ct-hero .left{max-width:1120px;}
.page-template-service-detail .ct-hero h1{max-width:none;}

/* --- mobile --- */
@media (max-width:768px){
  .page-template-service-detail .ct-editorial .blocks{padding:var(--sec-y) 18px;}
  .page-template-service-detail .ct-editorial .cb{display:flex;flex-direction:column;gap:0;max-width:none;}
  .page-template-service-detail .ct-editorial .cb.flip{flex-direction:column;}
  .page-template-service-detail .ct-editorial .cb + .cb{margin-top:30px;}
  .page-template-service-detail .ct-editorial .cb .img{order:0;width:100%;aspect-ratio:1/1;height:auto;min-height:0;border-radius:14px;}
  .page-template-service-detail .ct-editorial .cb .txt{order:1;position:relative;left:auto;right:auto;bottom:auto;width:auto;margin:-42px 14px 0;padding:20px 18px 14px;border-radius:14px;box-shadow:0 28px 56px -42px rgba(16,19,25,.5);z-index:2;}
  /* reset the desktop normal/flip horizontal offset (0,4,0 — leaks past the media query otherwise) */
  .page-template-service-detail .ct-editorial .cb.normal .txt,.page-template-service-detail .ct-editorial .cb.flip .txt{left:auto;right:auto;}
  .page-template-service-detail .ct-editorial .cb h3{font-size:26px;margin:13px 0 9px;line-height:1.08;}
  .page-template-service-detail .ct-editorial .cb p{font-size:13px;}
  .page-template-service-detail .ct-editorial .cb .pts{margin-top:14px;}
  .page-template-service-detail .designer{padding:var(--sec-y) 0;background:radial-gradient(440px 300px at 88% -8%,rgba(31,95,214,.1),transparent 70%);}
  .page-template-service-detail .dz-grid{grid-template-columns:1fr;gap:22px;padding:22px;border-radius:18px;}
  .page-template-service-detail .dz-h{font-size:26px;line-height:1.08;}
  .page-template-service-detail .dz-lead{margin-top:12px;font-size:13.5px;line-height:1.55;}
  .page-template-service-detail .dz-pts{margin-top:18px;gap:10px;}
  .page-template-service-detail .dz-pts li{font-size:13.5px;}
  .page-template-service-detail .dz-cta{margin-top:22px;gap:10px;flex-direction:column;align-items:stretch;}
  .page-template-service-detail .dz-cta .btn{justify-content:center;width:100%;}
  .page-template-service-detail .dz-note{text-align:center;}
  .page-template-service-detail .render>.wrap{padding:0;}
}
/* ===== /fc-ct-redesign-v1 ===== */

/* ===== fc-home-ct-v1 · homepage "02 Containment" cinematic video stage (replaces the prodcards grid) ===== */
.ct-block{padding:0;}
.ct-stage{position:relative;height:640px;background:#080b10;overflow:hidden;}
.ct-stage>video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.ct-stage .scrim{position:absolute;inset:0;z-index:2;background:linear-gradient(90deg,rgba(8,11,16,.9) 0%,rgba(8,11,16,.64) 42%,rgba(8,11,16,.12) 72%,transparent 100%);}
.ct-inner{position:absolute;inset:0;z-index:3;}
.ct-inner .wrap{width:100%;height:100%;}
.ct-copy{height:100%;max-width:580px;display:flex;flex-direction:column;justify-content:space-between;padding:60px 0;}
.ct-head h2{font-size:56px;line-height:1.02;letter-spacing:-.03em;color:#fff;max-width:none;}
.ct-head .secnum{margin-bottom:var(--eyb-gap);}
.ct-head .secnum .mono{color:rgba(255,255,255,.7);}
.ct-head p{margin-top:16px;font-size:17px;line-height:1.6;color:rgba(255,255,255,.78);max-width:46ch;}
.ct-copy .cta{display:flex;gap:14px;align-items:center;}
.ct-stage .btn-light{background:#fff;color:#16181d;border-color:transparent;}
.ct-stage .btn-light:hover{background:#fff;box-shadow:0 0 0 4px rgba(255,255,255,.2);}
.ct-tags{position:absolute;z-index:3;right:40px;bottom:34px;display:flex;gap:10px;}
.ct-tags span{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:rgba(255,255,255,.82);background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);border-radius:999px;padding:7px 13px;backdrop-filter:blur(8px);}
@media (max-width:768px){
  .ct-stage{height:76vh;height:76svh;min-height:560px;}
  .ct-stage .scrim{background:linear-gradient(180deg,rgba(8,11,16,.78) 0%,rgba(8,11,16,.32) 40%,rgba(8,11,16,.55) 70%,rgba(8,11,16,.9) 100%);}
  .ct-copy{max-width:none;padding:34px 0;}
  .ct-head h2{font-size:32px;line-height:1.04;}
  .ct-head p{font-size:14px;margin-top:12px;}
  .ct-copy .cta{width:100%;}
  .ct-stage .btn-light{width:100%;justify-content:center;}
  .ct-tags{display:none;}
}
/* ===== /fc-home-ct-v1 ===== */

/* ===== fc-home-msvc-v1 · homepage 01 Services — compact MOBILE layout (featured UPS card kept; services 2-5 become compact rows). Desktop bento unchanged. ===== */
.m-svc-rows{display:none;}
@media (max-width:768px){
  /* hide the 4 non-featured tiles + the featured card's tag chips; keep .t-ups as the featured card */
  .svc .t-mon,.svc .t-mnt,.svc .t-load,.svc .t-clean{display:none;}
  .svc .t-ups .tags{display:none;}
  /* featured UPS card: make the illustration panel full-bleed (no left/bottom/right padding) and bigger */
  .svc .t-ups{padding:0;overflow:hidden;}
  .svc .t-ups .colL{padding:20px 20px 0;}
  .svc .t-ups .frame{margin:16px 0 0;height:260px;min-height:0;border:0;border-radius:0;}
  .svc .t-ups .frame::after{display:none;}
  /* compact rows, in the live card style (white, 1px line, r14, fc-cardgrid shadow) */
  .m-svc-rows{display:flex;flex-direction:column;gap:12px;margin-top:12px;}
  .m-svc-rows .m-srow{display:flex;align-items:center;gap:12px;border:1px solid var(--line);border-radius:14px;background:var(--paper);box-shadow:0 14px 30px -26px rgba(30,42,64,.5);padding:14px 16px;color:inherit;transition:background .15s ease,transform .15s ease;}
  .m-svc-rows .m-srow:active{transform:translateY(-1px);background:#f7f9fc;}
  .m-svc-rows .m-srow .n{font-family:var(--mono);font-size:10px;letter-spacing:.06em;color:var(--ink-3);width:24px;flex:none;align-self:flex-start;padding-top:3px;}
  .m-svc-rows .m-srow .mid{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px;}
  .m-svc-rows .m-srow .tt{font-size:15.5px;font-weight:500;letter-spacing:-.015em;color:var(--ink);}
  .m-svc-rows .m-srow .sub{font-size:11.5px;color:var(--ink-2);line-height:1.35;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  .m-svc-rows .m-srow .ar{color:var(--ink-3);font-size:14px;flex:none;align-self:center;}
}
/* ===== /fc-home-msvc-v1 ===== */

/* ===== fc-svc-badge-v1 · coloured 2-letter service badge (menu-dropdown .ic style) beside titles + in compact rows; replaces the 01/05 numbering ===== */
.svc-ic{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;flex:none;border-radius:8px;font-family:var(--mono);font-size:11px;font-weight:500;line-height:1;letter-spacing:0;color:var(--svc-ink,var(--accent));background:rgba(31,95,214,.1);background:color-mix(in srgb, var(--svc-ink, var(--accent)) 13%, transparent);}
.svc-th{display:flex;align-items:center;gap:11px;}
.tile .svc-th h3{margin-top:0;}
.m-svc-rows .m-srow .svc-ic{align-self:center;}
/* ===== /fc-svc-badge-v1 ===== */

/* ===== fc-eyebrow-v1 · canonical slash-mono section eyebrow, SITE-WIDE ("// label", lowercase, no numbers). ===== */
/* ONE knob for the eyebrow->title gap site-wide: 12px desktop, 8px mobile. Every section/content
   eyebrow margin-bottom reads var(--eyb-gap). Heroes (.eyebrow in hero) + deliberate-0 contexts opt out. */
:root{--eyb-gap:12px;}
.secnum,.m-secnum,.seclab,.m-seclab,.eyebrow,.pfc-seclab,.ct-seclab{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-size:13px;font-weight:600;letter-spacing:.02em;white-space:nowrap;}
.secnum,.m-secnum,.seclab,.m-seclab,.eyebrow,.pfc-seclab,.ct-seclab{margin-bottom:var(--eyb-gap);}
:is(.secnum,.m-secnum,.seclab,.m-seclab,.eyebrow,.pfc-seclab,.ct-seclab,.dlab) + :is(h1,h2,h3,h4){margin-top:0 !important;}
.lhs > h2:not(:last-child){margin-bottom:14px;}
.cases-head .seclab,.cases-head .secnum{margin-bottom:0;}
.secnum .s,.m-secnum .s,.seclab .s,.m-seclab .s,.eyebrow .s,.pfc-seclab .s,.ct-seclab .s{color:var(--accent);}
.secnum .l,.m-secnum .l,.seclab .l,.m-seclab .l,.eyebrow .l,.pfc-seclab .l,.ct-seclab .l{color:var(--ink);text-transform:lowercase;letter-spacing:.04em;}
@media (max-width:768px){:root{--eyb-gap:8px;}.secnum,.m-secnum,.seclab,.m-seclab,.eyebrow,.pfc-seclab,.ct-seclab{font-size:12px;}}
/* dark contexts: the // goes light-blue + label white (mirrors where the old .mono was white) */
.hero .s,.m-hero .s,.cs-ghero .s,.m-cs-ghero .s,.werken .s,.m-werken .s,.evp-dark .s,.acad .s,.acad-hero .s,.apply-l .s,.sp-cta .s,.ct-copy .s{color:#6f9bff;}
.hero .l,.m-hero .l,.cs-ghero .l,.m-cs-ghero .l,.werken .l,.m-werken .l,.evp-dark .l,.acad .l,.acad-hero .l,.apply-l .l,.sp-cta .l,.ct-copy .l{color:#fff;}
/* homepage keeps its extra-tight eyebrow->title distance (line-height + 11px) */
.home .sechead h2,.home .werken h2{line-height:1.04;}
/* ===== /fc-eyebrow-v1 ===== */

/* ===== fc-svc-iso-v1 · iso drawings on the service/product pages: panning render hero + static content boards ===== */
.page-template-service-detail .svc-heroimg.svc-render{background:#0e1118;border-color:#1e2733;}
.page-template-service-detail .svc-heroimg.svc-render::after{background:linear-gradient(120deg,rgba(31,95,214,.12),transparent 62%);}
.svc-render-pan{position:absolute;inset:0;overflow:hidden;}
.svc-render-pan svg{position:absolute;top:50%;left:50%;height:160%;width:auto;transform:translate(-50%,-50%);animation:svcPan 32s ease-in-out infinite alternate;}
@keyframes svcPan{from{transform:translate(-60%,-50%);}to{transform:translate(-40%,-50%);}}
@media (prefers-reduced-motion:reduce){.svc-render-pan svg{animation:none;}}
.page-template-service-detail .cb .img.tdraw{background:#10141b;border-color:#1e2733;aspect-ratio:3/2;min-height:0;align-self:center;overflow:hidden;}
.page-template-service-detail .cb .img.tdraw::after{display:none;}
@media (max-width:768px){.page-template-service-detail .cb .img.tdraw{height:auto;align-self:stretch;width:100%;}}
/* ===== /fc-svc-iso-v1 ===== */

/* ===== fc-svc-dark-v1 · service-detail work-package block in a DARK theme (hero render removed; eyebrow "overzicht"; no wp-head; pane eyebrows are // label) ===== */
.page-template-service-detail .svc-dark .md .cols{background:#0e1118;border-color:#1e2733;box-shadow:0 30px 64px -44px rgba(8,11,16,.7);}
.page-template-service-detail .svc-dark .md .list{border-right-color:rgba(255,255,255,.08);}
.page-template-service-detail .svc-dark .md .list label{border-bottom-color:rgba(255,255,255,.07);}
.page-template-service-detail .svc-dark .md .list label .n{color:rgba(255,255,255,.45);}
.page-template-service-detail .svc-dark .md .list label .t{color:rgba(255,255,255,.82);}
.page-template-service-detail .svc-dark .md .list label .ar{color:rgba(255,255,255,.5);}
.page-template-service-detail .svc-dark .md .list label:hover{background:rgba(255,255,255,.05);}
.page-template-service-detail .svc-dark .md .detail{background:linear-gradient(180deg,#13171f,#0e1118);}
.page-template-service-detail .svc-dark .md .pane h4{color:#fff;}
.page-template-service-detail .svc-dark .md .pane p{color:rgba(255,255,255,.74);}
.page-template-service-detail .svc-dark .md .pane .pn{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-size:13px;font-weight:600;letter-spacing:.02em;}
.page-template-service-detail .svc-dark .md .pane .pn .s{color:#6f9bff;}
.page-template-service-detail .svc-dark .md .pane .pn .l{color:rgba(255,255,255,.72);text-transform:lowercase;letter-spacing:.04em;}
@media (max-width:768px){
  .page-template-service-detail .svc-dark .svc-acc{background:#0e1118;border-color:#1e2733;border-radius:14px;overflow:hidden;}
  .page-template-service-detail .svc-dark .svc-acc details{border-top-color:rgba(255,255,255,.08);}
  .page-template-service-detail .svc-dark .svc-acc summary .k{color:#fff;}
  .page-template-service-detail .svc-dark .svc-acc summary .v{color:rgba(255,255,255,.6);}
  .page-template-service-detail .svc-dark .svc-acc summary .pm{background:transparent;border-color:color-mix(in srgb,var(--svc,#6f9bff) 50%,transparent);color:var(--svc,#6f9bff);}
  .page-template-service-detail .svc-dark .svc-acc details[open] summary{background:rgba(255,255,255,.04);}
  .page-template-service-detail .svc-dark .svc-acc details[open] summary .pm{background:var(--svc,#6f9bff);border-color:var(--svc,#6f9bff);color:#0e1118;}
  .page-template-service-detail .svc-dark .svc-acc .more{background:rgba(255,255,255,.03);}
  .page-template-service-detail .svc-dark .svc-acc .more p{color:rgba(255,255,255,.72);}
}
.page-template-service-detail .svc-wp{padding:var(--sec-y) 0;}
.page-template-service-detail .svc-wp .md .cols{margin-top:45px;}
@media (max-width:768px){.page-template-service-detail .svc-wp .svc-acc{margin-top:45px;}}
.page-template-service-detail .svc-wp + .svc-ov{padding-top:36px;}
.page-template-service-detail .svc-wp + .svc-ov .ov-intro{margin-top:0;}
@media (max-width:768px){.page-template-service-detail .svc-wp{padding:var(--sec-y) 0;}.page-template-service-detail .svc-wp + .svc-ov{padding-top:20px;}}
/* ===== /fc-svc-dark-v1 ===== */

/* ===== fc-aurora-v1 · continuous "Aurora" background: ONE fixed layer behind all content; blue blobs drift+breathe very slowly ===== */
.bg{position:fixed;inset:0;z-index:-1;overflow:hidden;pointer-events:none;background:linear-gradient(180deg,#eef0f3 0%,#e7eaef 50%,#eceef2 100%);}
.bg .blob{position:absolute;border-radius:50%;filter:blur(70px);will-change:transform;}
.bg .a1{width:780px;height:780px;left:-12%;top:-14%;background:radial-gradient(circle,rgba(31,95,214,.30),transparent 66%);animation:bgDrift1 64s ease-in-out infinite;}
.bg .a2{width:680px;height:680px;right:-10%;top:24%;background:radial-gradient(circle,rgba(64,120,230,.22),transparent 66%);animation:bgDrift2 82s ease-in-out infinite;}
.bg .a3{width:900px;height:900px;left:18%;bottom:-26%;background:radial-gradient(circle,rgba(40,80,170,.18),transparent 66%);animation:bgDrift3 98s ease-in-out infinite;}
@keyframes bgDrift1{0%{transform:translate(0,0) scale(1);}50%{transform:translate(14vw,10vh) scale(1.32);}100%{transform:translate(0,0) scale(1);}}
@keyframes bgDrift2{0%{transform:translate(0,0) scale(1.1);}50%{transform:translate(-12vw,8vh) scale(.82);}100%{transform:translate(0,0) scale(1.1);}}
@keyframes bgDrift3{0%{transform:translate(0,0) scale(.9);}50%{transform:translate(-8vw,-12vh) scale(1.25);}100%{transform:translate(0,0) scale(.9);}}
@media (prefers-reduced-motion:reduce){.bg .blob{animation:none !important;}}
/* free the GPU for the mobile menu (the heavy blur was stalling its open animation) */
body.menu-open .bg{display:none;}
/* mobile: NO aurora — it's a DESKTOP-only treatment (user, 2026-06-26). Hide the whole fixed layer and paint the entire mobile page the SAME flat colour as the iOS safe-area band (#eceef2 = aurora base), so the page is one uniform colour edge to edge with zero band mismatch. Desktop keeps the live aurora, so body stays transparent there (only overridden here, where .bg is gone so there's nothing to cover). */
@media (max-width:768px){.bg{display:none;}body{background:#eceef2;}}
/* ===== /fc-aurora-v1 ===== */

/* ===== fc-fixbatch-20260625 · listed UI fixes ===== */
/* #2 home: "Bekijk alle cases" centered below the 3 case cards (was top-right) */
.cs-more{display:flex;justify-content:center;margin-top:36px;}
@media(max-width:768px){.cs-more{margin-top:24px;}.cs-more .btn{width:100%;justify-content:center;}}

/* #4 werken-bij: big academy section labels (e.g. "Vijf manieren waarop wij
   investeren") were white-space:nowrap and pushed the page wider than the
   viewport on mobile -> horizontal scroll. Let them wrap. */
.page-slug-werken-bij .acad .dlabel.ac2 .mono{white-space:normal;}

/* #11 home client strip ("Vertrouwd door") dark again so it reads as part of the
   dark hero; shorter on mobile. */
/* trust is now a glass marquee bar OVER the hero video (moved inside .hero): semi-
   transparent + backdrop-blur so the looping video shows frosted behind it. */
.hero .trust{position:absolute;left:0;right:0;bottom:0;z-index:4;background:rgba(11,14,20,.42);backdrop-filter:blur(16px) saturate(1.45);-webkit-backdrop-filter:blur(16px) saturate(1.45);border-top:1px solid rgba(255,255,255,.14);}
.trust .lbl{color:rgba(255,255,255,.62);}
.trust .marquee{border-left-color:rgba(255,255,255,.2);}
.trust .track span{color:rgba(255,255,255,.9);}
/* all mobile heroes use the 518 over-fill (min-height:calc(100lvh+10vh)) so they always cover the viewport (no white strip). The home .trust marquee flows in below the hero content (position:static). */
/* mobile: the "Vertrouwd door" marquee is a glass bar pinned to the BOTTOM of the hero video (like desktop), not in flow. It keeps the absolute;bottom:0 from the base rule above; safe-area padding lifts it off the home indicator. */
@media(max-width:768px){.trust .wrap{height:46px;}.hero .trust{padding-bottom:env(safe-area-inset-bottom);}}

/* #10 dark page heroes float as a rounded card (desktop only). On home the client
   strip joins the hero into one continuous card (no gap between them). */
@media(min-width:769px){.hero{margin:10px;border-radius:18px;}}
/* #6 round the isometric render frames on service/product detail + case detail.
   Hero render image only rounded on desktop (full-bleed on mobile). */
@media(min-width:769px){
  .page-template-service-detail .svc-heroimg,
  .single-fc_case .svc-heroimg{border-radius:14px;overflow:hidden;}
}
.page-template-service-detail .cb .img.tdraw,
.single-fc_case .cb .img.tdraw,
.single-fc_case .m-cb .img.tdraw{border-radius:14px;overflow:hidden;}

/* #7 the service/product render hero was zoomed to 160% (cropped). Bring it close
   to the case-detail boards (whole drawing visible) with only a gentle pan. */
.svc-render-pan svg{height:116%;}
@keyframes svcPan{from{transform:translate(-53%,-50%);}to{transform:translate(-47%,-50%);}}
/* #9 featured vacancies on home: reuse the vacancy-card look (the base rules are
   scoped to .page-slug-vacatures, so mirror them under body.home). */
body.home .vac-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
body.home .vac-card{display:flex;flex-direction:column;gap:9px;text-decoration:none;color:inherit;background:linear-gradient(165deg,#fafbfc 0%,#eef1f5 100%);border:1px solid var(--line);border-left:3px solid var(--line-2);border-radius:13px;padding:22px 24px;min-height:140px;transition:background .3s ease,border-color .25s ease;}
body.home .vac-card:hover{background:linear-gradient(165deg,#ffffff 0%,#eef2f7 100%);border-left-color:var(--accent);}
body.home .vac-card.feat{border-color:rgba(31,95,214,.4);border-left:3px solid var(--accent);background:linear-gradient(165deg,#f3f7ff 0%,#e8eef9 100%);}
body.home .vac-card .vc-top{display:flex;justify-content:space-between;align-items:baseline;gap:12px;}
body.home .vac-card .vc-title{font-size:18px;font-weight:600;letter-spacing:-.015em;color:var(--ink);line-height:1.2;}
body.home .vac-card .vc-loc{font-family:var(--mono);font-size:10px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3);white-space:nowrap;flex:none;}
body.home .vac-card .vc-meta{font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3);}
body.home .vac-card .vc-foot{margin-top:auto;padding-top:14px;display:flex;justify-content:space-between;align-items:baseline;gap:10px;}
body.home .vac-card .vc-pay{font-family:var(--mono);font-size:13px;font-weight:500;color:var(--ink);}
body.home .vac-card .vc-go{font-family:var(--mono);font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--accent);white-space:nowrap;}
body.home .vac-card .vc-go .ar{display:inline-block;transition:transform .2s ease;}
body.home .vac-card:hover .vc-go .ar{transform:translateX(3px);}
@media(max-width:768px){body.home .vac-grid{grid-template-columns:1fr;gap:10px;}body.home .vac-card{padding:16px 18px;border-radius:12px;min-height:0;}body.home .vac-card .vc-title{font-size:16px;}body.home .vac-card .vc-foot{margin-top:6px;padding-top:10px;border-top:1px solid var(--line);}}
/* ===== fc-fixbatch2-20260625 ===== */
/* #19 home featured vacancies now live INSIDE the dark .werken block as dark cards
   (overrides the lighter body.home .vac-card rules above via higher specificity). */
.werken .wk-vacs{margin-top:30px;}
.werken .wk-vacs-h{font-size:24px;letter-spacing:-.02em;color:#fff;margin-bottom:20px;}
.werken .wk-vacs .vac-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;}
/* #24 home vacancy cards mirror the career-explorer "Alle vacatures" card (compact:
   level tag + title + open chip / salary + CTA), dark-themed for the .werken block.
   Mobile = explorer size; desktop = same setup slightly bigger, 3 across. */
.werken .wkv{display:flex;flex-direction:column;text-decoration:none;color:inherit;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:12px 14px;transition:background .2s ease,border-color .2s ease,transform .12s ease;}
.werken .wkv:hover{background:rgba(127,176,255,.1);border-color:rgba(127,176,255,.4);transform:translateY(-2px);}
.werken .wkv .wkv-h{display:flex;align-items:flex-start;gap:10px;}
.werken .wkv .wkv-t{font-size:14.5px;font-weight:600;letter-spacing:-.015em;color:#fff;flex:1;min-width:0;line-height:1.25;}
.werken .wkv .wkv-chip{flex:none;display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:9px;letter-spacing:.06em;text-transform:uppercase;color:#9cc0ff;border:1px solid rgba(127,176,255,.32);border-radius:999px;padding:3px 8px;}
.werken .wkv .wkv-dot{width:6px;height:6px;border-radius:50%;background:#3ace8b;box-shadow:0 0 7px rgba(58,206,139,.9);flex:none;}
.werken .wkv .wkv-foot{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-top:auto;padding-top:14px;}
.werken .wkv .wkv-pay{font-family:var(--mono);font-size:11.5px;color:#fff;}
.werken .wkv .wkv-pay .ex{color:#9aa3b2;}
.werken .wkv .wkv-go{font-family:var(--mono);font-size:9.5px;letter-spacing:.04em;text-transform:uppercase;color:#7fb0ff;white-space:nowrap;}
.werken .wkv .wkv-go .ar{display:inline-block;transition:transform .2s ease;}
.werken .wkv:hover .wkv-go .ar{transform:translateX(3px);}
/* block CTA = the home hero "Bekijk vacatures" button, but blue (btn-primary) with the live count as a badge inside (no separate chip) */
.werken .wk-allvac .dot{width:7px;height:7px;border-radius:50%;background:#fff;box-shadow:0 0 8px rgba(255,255,255,.7);}
.werken .wk-allvac .badge{font-family:var(--mono);font-size:10px;color:#fff;padding:2px 7px;border:1px solid rgba(255,255,255,.5);border-radius:999px;background:rgba(255,255,255,.14);}
@media(min-width:769px){
  .werken .wkv{padding:15px 17px;border-radius:13px;}
  .werken .wkv .wkv-t{font-size:15.5px;}
  .werken .wkv .wkv-pay{font-size:12.5px;}
}
.werken .wk-vacs-cta{display:flex;align-items:center;justify-content:center;gap:14px;margin-top:40px;flex-wrap:wrap;}
@media(max-width:768px){.werken .wk-vacs .vac-grid{grid-template-columns:1fr;gap:10px;}.werken .wk-vacs-h{font-size:20px;}}

/* #16 home containment video block floats as a rounded card, like the heroes (desktop) */
@media(min-width:769px){.ct-stage{margin:10px;border-radius:18px;}}

/* #17 cases globe heroes: same float + rounding as the other heroes (desktop) */
@media(min-width:769px){
  .post-type-archive-fc_case .cs-ghero,
  .single-fc_case .case-ghero{margin:10px;border-radius:18px;}
}

/* #18 "Vertrouwd door" marquee: tighter spacing between client names on mobile */
@media(max-width:768px){.trust .track span{padding:0 16px;}}

/* #22 werken-bij Academy ("// doorgroeien") block floats rounded like the heroes (desktop) */
@media(min-width:769px){.page-slug-werken-bij .acad{margin:10px;border-radius:18px;overflow:hidden;}}

/* #27 related-cases section (service-detail) gets a real H2 heading; the // eyebrow
   is the kicker above it (same shape as the homepage cases section header). Also
   covers the "meer diensten" header (#32), which now uses the same cases-head/lhs.
   The case-detail "Andere cases" head (.single-fc_case) reuses the same shape. */
.page-template-service-detail .cases-head .lhs,.single-fc_case .cases-head .lhs{display:flex;flex-direction:column;}
.page-template-service-detail .cases-head .lhs .seclab,.single-fc_case .cases-head .lhs .seclab{margin-bottom:var(--eyb-gap);}
.page-template-service-detail .cases-head h2,.single-fc_case .cases-head h2{font-size:30px;letter-spacing:-.03em;}
@media(max-width:768px){.page-template-service-detail .cases-head h2,.single-fc_case .cases-head h2{font-size:24px;}}

/* #28 service "meer diensten": 5 cards across (4 services + containment as the 5th),
   new card style via .fc-cardgrid; mobile reuses the narrow .other cards (#3). */
.page-template-service-detail .other.other-5{grid-template-columns:repeat(5,1fr);}

/* #31 service "onze aanpak" steps -> new separated card style (was old flush panel) */
.page-template-service-detail .appr{gap:24px;background:transparent;border-radius:0;overflow:visible;box-shadow:none;}
.page-template-service-detail .appr .c{border:1px solid var(--line);border-radius:14px;background:var(--paper);box-shadow:0 14px 30px -26px rgba(30,42,64,.5);transition:box-shadow .3s ease,transform .3s ease;}
.page-template-service-detail .appr .c:hover{transform:translateY(-3px);box-shadow:0 30px 60px -34px rgba(30,42,64,.55);background:var(--paper);}

/* #39/#42 vacancy-detail section titles (eyebrow kicker + H2). #43 moved eyebrows
   (salary/quote/team) sit inside their block via the canonical 12px eyebrow gap. */
.page-template-vacancy-detail .vd-h2{font-size:30px;letter-spacing:-.03em;margin-bottom:30px;}
.page-template-vacancy-detail .vd-sechead .secnum{margin-bottom:var(--eyb-gap);}
.page-template-vacancy-detail .vd-sechead .vd-h2{margin-bottom:10px;}
@media(max-width:768px){.page-template-vacancy-detail .vd-h2{font-size:24px;margin-bottom:20px;}}

/* #33 meer-diensten cards = home-style with the coloured per-service badge; no chip,
   no 01/02 number, copy clamped to 3 lines, a bit shorter on desktop. */
.page-template-service-detail .other.svc-badged a{min-height:0;padding:20px 22px;}
.page-template-service-detail .other.svc-badged a .svc-ic{width:34px;height:34px;border-radius:9px;font-size:12px;}
.page-template-service-detail .other.svc-badged a h4{margin-top:14px;font-size:18px;font-weight:500;letter-spacing:-.02em;line-height:1.2;}
.page-template-service-detail .other.svc-badged a p{margin-top:8px;font-size:13.5px;color:var(--ink-2);line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}
.page-template-service-detail .other.svc-badged a .go{margin-top:14px;}
@media(max-width:768px){
  .page-template-service-detail .other.svc-badged a{display:grid;grid-template-columns:auto 1fr auto;align-items:center;column-gap:12px;padding:12px 14px;}
  .page-template-service-detail .other.svc-badged a .svc-ic{grid-column:1;grid-row:1 / 3;align-self:center;width:30px;height:30px;}
  .page-template-service-detail .other.svc-badged a h4{grid-column:2;grid-row:1;margin:0;font-size:15px;}
  .page-template-service-detail .other.svc-badged a p{grid-column:2;grid-row:2;margin-top:2px;font-size:11.5px;-webkit-line-clamp:1;}
  .page-template-service-detail .other.svc-badged a .go{grid-column:3;grid-row:1 / 3;align-self:center;margin:0;font-size:0;}
  .page-template-service-detail .other.svc-badged a .go .ar{font-size:14px;color:var(--ink-3);}
}
/* #48 academy "startersfuncties" use the same compact dark card grid as the home
   //werken-bij wkv vacancy cards (dark, rounded, hover-blue), desktop + mobile. */
.page-slug-werken-bij .acad .starters{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;border:0;border-radius:0;overflow:visible;background:transparent;box-shadow:none;}
.page-slug-werken-bij .acad .st-row{display:flex;flex-direction:column;align-items:stretch;gap:7px;border:1px solid rgba(255,255,255,.12);border-radius:12px;background:rgba(255,255,255,.04);padding:16px 18px;transition:background .2s ease,border-color .2s ease,transform .12s ease;}
.page-slug-werken-bij .acad .st-row:hover{background:rgba(127,176,255,.1);border-color:rgba(127,176,255,.4);transform:translateY(-2px);}
.page-slug-werken-bij .acad .st-n{display:none;}
.page-slug-werken-bij .acad .st-main{display:flex;flex-direction:column;gap:5px;}
.page-slug-werken-bij .acad .st-note{font-size:12px;color:rgba(255,255,255,.58);line-height:1.45;}
.page-slug-werken-bij .acad .st-pay{margin-top:auto;padding-top:10px;text-align:left;font-family:var(--mono);font-size:13px;font-weight:500;color:#fff;}
.page-slug-werken-bij .acad .st-row .applybtn{align-self:flex-start;background:none;border:0;box-shadow:none;padding:0;color:#7fb0ff;font-family:var(--mono);font-size:9.5px;letter-spacing:.04em;text-transform:uppercase;}
.page-slug-werken-bij .acad .st-row .apply-off{color:rgba(255,255,255,.4);}
/* desktop: status chip pinned top-right, "Bekijk vacature" pinned bottom-right of each starter card */
@media(min-width:769px){
  .page-slug-werken-bij .acad .st-row{position:relative;}
  .page-slug-werken-bij .acad .st-main{padding-right:78px;}
  .page-slug-werken-bij .acad .st-t .chip-glow,.page-slug-werken-bij .acad .st-t .lvfilled{position:absolute;top:15px;right:16px;margin-top:0;}
  .page-slug-werken-bij .acad .st-row .applybtn,.page-slug-werken-bij .acad .st-row .apply-off{position:absolute;bottom:14px;right:18px;align-self:auto;}
}
@media(max-width:768px){.page-slug-werken-bij .acad .starters{grid-template-columns:1fr;}}

/* #44 legal / plain-content pages (privacy policy): title clear of the topbar,
   readable legal column with proper margins. fc-legal-v1. */
.legal-hero{padding-top:150px;padding-bottom:0;}
.legal-hero .legal-h1{font-size:44px;letter-spacing:-.03em;margin-top:6px;}
.legal-sec{padding-top:34px;}
.legal-body{max-width:760px;color:var(--ink-2);line-height:1.7;font-size:16px;}
.legal-body h1,.legal-body h2{font-size:24px;letter-spacing:-.02em;color:var(--ink);margin:38px 0 12px;}
.legal-body h3{font-size:18px;letter-spacing:-.01em;color:var(--ink);margin:28px 0 10px;}
.legal-body p{margin:0 0 16px;}
.legal-body ul,.legal-body ol{margin:0 0 16px;padding-left:22px;}
.legal-body li{margin:6px 0;}
.legal-body a{color:var(--accent);text-decoration:underline;}
.legal-body strong,.legal-body b{color:var(--ink);}
@media(max-width:768px){.legal-hero{padding-top:116px;}.legal-hero .legal-h1{font-size:30px;}}
/* ===== /fc-fixbatch2-20260625 ===== */
/* ===== /fc-fixbatch-20260625 ===== */

/* fc-capture-v1 · capture-first apply form: subtitle under the form title */
.apply-form .ff-sub{margin:-6px 0 18px;font-size:14.5px;line-height:1.5;color:#5d6b7a}

/* ================================================================
   fc-verdieping-v1 · post-submit deepening chat (page-slug-verdieping)
   Light panel on the shared aurora bg; brand-blue accents; the chat
   fills comfortably on mobile where most candidates arrive.
   ================================================================ */
.vdp{max-width:720px;margin:0 auto;background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:26px 26px 20px;box-shadow:0 18px 44px -18px rgba(27,29,34,.18);}
.vdp-head{display:flex;gap:16px;align-items:flex-start;padding-bottom:18px;border-bottom:1px solid var(--line);}
.vdp-check{flex:0 0 46px;width:46px;height:46px;border-radius:50%;border:2px solid var(--accent);display:flex;align-items:center;justify-content:center;color:var(--accent);box-shadow:0 0 0 6px rgba(31,95,214,.07);}
.vdp-check svg{width:22px;height:22px;}
.vdp-eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:.08em;color:var(--accent);margin-bottom:12px;}
.vdp-h1{font-size:clamp(20px,3.2vw,26px);line-height:1.2;margin:0 0 8px;}
.vdp-sub{font-size:14.5px;line-height:1.55;color:var(--ink-2);margin:0;}
.vdp-chat{min-height:180px;max-height:52vh;overflow-y:auto;padding:18px 2px;display:flex;flex-direction:column;gap:10px;}
.vdp-msg{display:flex;}
.vdp-msg.vdp-user{justify-content:flex-end;}
.vdp-bubble{max-width:82%;padding:10px 14px;border-radius:14px;font-size:14.5px;line-height:1.5;white-space:pre-wrap;overflow-wrap:break-word;word-break:break-word;}
.vdp-ai .vdp-bubble{background:var(--bg);color:var(--ink);border:1px solid var(--line);border-bottom-left-radius:4px;}
.vdp-user .vdp-bubble{background:var(--accent);color:#fff;border-bottom-right-radius:4px;}
.vdp-typing .vdp-bubble{display:flex;gap:5px;align-items:center;padding:13px 16px;}
.vdp-dot{width:7px;height:7px;border-radius:50%;background:var(--ink-3);animation:vdpDot 1.2s infinite;}
.vdp-dot:nth-child(2){animation-delay:.15s;}
.vdp-dot:nth-child(3){animation-delay:.3s;}
@keyframes vdpDot{0%,60%,100%{opacity:.35;transform:translateY(0);}30%{opacity:1;transform:translateY(-3px);}}
.vdp-inputrow{display:flex;gap:10px;padding-top:6px;}
.vdp-inputrow input{flex:1;min-width:0;padding:12px 16px;border:1px solid var(--line-2);border-radius:999px;font:inherit;font-size:16px;background:var(--paper);color:var(--ink);} /* 16px: onder de 16 zoomt iOS Safari in */
.vdp-inputrow input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(31,95,214,.12);}
.vdp-inputrow input:disabled{background:var(--bg);color:var(--ink-3);}
.vdp-send{flex:0 0 auto;border-radius:999px;padding:12px 20px;font-size:17px;line-height:1;}
.vdp-send:disabled{opacity:.45;cursor:default;}
.vdp-done{margin-top:22px;text-align:center;}
.vdp-cta{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;}
@media (max-width:768px){
  .vdp{padding:18px 14px 14px;border-radius:14px;}
  .vdp-chat{max-height:none;min-height:200px;}
  .vdp-bubble{max-width:88%;}
}

/* fc-verdieping-v1 · de nav is position:absolute en zweeft over de pagina
   (desktop top:22px, ~84px onderkant; mobiel top:14px + 56px balk, ~70px). De
   chat-kaart schoof eronder, dus per breakpoint genoeg bovenruimte zodat de
   kaart vrij onder de nav uitkomt. */
.page-slug-verdieping .vd-sec{padding-top:calc(88px + env(safe-area-inset-top));}
@media (min-width:769px){
  .page-slug-verdieping .vd-sec{padding-top:118px;}
}
