/* ============================================================
   ReBrand Enschede — main stylesheet
   ============================================================ */

/* ---- Fonts ---- */
@font-face{font-family:"Lemon Milk";src:url("../fonts/LEMONMILK-Light.otf") format("opentype");font-weight:300;font-style:normal;font-display:swap}
@font-face{font-family:"Lemon Milk";src:url("../fonts/LEMONMILK-Regular.otf") format("opentype");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Lemon Milk";src:url("../fonts/LEMONMILK-Medium.otf") format("opentype");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Lemon Milk";src:url("../fonts/LEMONMILK-Bold.otf") format("opentype");font-weight:700;font-style:normal;font-display:swap}

/* ---- Tokens ---- */
:root{
	--rbe-red:#e30613;
	--rbe-red-2:#f10000;
	--rbe-white:#ffffff;
	--rbe-ink:#161616;
	--rbe-muted:#5b5b5b;
	--rbe-radius:28px;
	--rbe-radius-lg:40px;
	--font-display:"Lemon Milk",system-ui,sans-serif;
	--font-body:"Montserrat",system-ui,sans-serif;
	--ease:cubic-bezier(.22,1,.36,1);
	--topbar-h:96px;
	--label-w:96px;
}

/* ---- Reset / base ---- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--font-body);color:var(--rbe-ink);background:var(--rbe-white);line-height:1.6;overflow-x:hidden}
body.rbe-menu-open{overflow:hidden}
/* Scrollbars in ReBrand-stijl */
*{scrollbar-width:thin;scrollbar-color:var(--rbe-red) rgba(0,0,0,.08)}
::-webkit-scrollbar{width:12px;height:12px}
::-webkit-scrollbar-track{background:rgba(0,0,0,.06)}
::-webkit-scrollbar-thumb{background:var(--rbe-red);border-radius:8px;border:3px solid transparent;background-clip:content-box}
::-webkit-scrollbar-thumb:hover{background:#b00410;background-clip:content-box}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;line-height:1.02;letter-spacing:.01em;margin:0}
.rbe-main{min-height:100vh}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}

/* ---- Topbar: brand + hamburger ---- */
.rbe-topbar{position:fixed;inset:0 0 auto 0;height:var(--topbar-h);display:flex;align-items:center;justify-content:space-between;padding:0 clamp(18px,3vw,46px);z-index:100000;pointer-events:none}
body.admin-bar .rbe-topbar{top:32px}
@media(max-width:782px){body.admin-bar .rbe-topbar{top:46px}}
.rbe-brand{pointer-events:auto;position:absolute;left:0;top:0;width:max(var(--label-w),64px);height:var(--topbar-h);display:flex;align-items:center;justify-content:center}
.rbe-brand img{width:auto;max-width:54px;max-height:54px;object-fit:contain}

.rbe-burger{pointer-events:auto;position:relative;width:46px;height:34px;display:grid;align-content:space-between;padding:4px 0;z-index:120;margin-left:auto}
.rbe-burger span{display:block;height:5px;width:100%;background:var(--rbe-red);border-radius:6px;transition:transform .45s var(--ease),opacity .3s var(--ease),background .3s}
.rbe-redpage .rbe-burger span{background:#fff}
.rbe-menu-open .rbe-burger span{background:var(--rbe-red)!important}
.rbe-menu-open .rbe-burger span:nth-child(1){transform:translateY(9.5px) rotate(45deg)}
.rbe-menu-open .rbe-burger span:nth-child(2){opacity:0}
.rbe-menu-open .rbe-burger span:nth-child(3){transform:translateY(-9.5px) rotate(-45deg)}

/* ---- Vertical labels ---- */
.rbe-vlabel{position:fixed;left:0;top:0;height:100vh;width:var(--label-w);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:clamp(28px,3.4vw,46px);letter-spacing:.06em;writing-mode:vertical-rl;transform:rotate(180deg);z-index:40;pointer-events:none;user-select:none}
.rbe-vlabel--light{color:var(--rbe-white);background:var(--rbe-red)}
.rbe-vlabel--dark{color:var(--rbe-red);background:transparent}

/* ============================================================
   MENU OVERLAY — bento (3 kol x 2 rij)
   ============================================================ */
.rbe-menu{position:fixed;inset:0;z-index:100;background:var(--rbe-white);display:flex;flex-direction:column;padding:calc(var(--topbar-h) + 20px) clamp(20px,4vw,64px) 0;opacity:0;visibility:hidden;transform:translateY(-12px);transition:opacity .5s var(--ease),transform .5s var(--ease),visibility 0s .5s}
.rbe-menu-open .rbe-menu{opacity:1;visibility:visible;transform:none;transition:opacity .5s var(--ease),transform .5s var(--ease)}
.rbe-menu__bento{flex:1;display:grid;grid-template-columns:1fr 1fr 1fr;grid-template-rows:1fr 1fr;gap:clamp(12px,1.4vw,22px);min-height:0;padding-bottom:20px}
.rbe-menu__card{position:relative;border-radius:var(--rbe-radius-lg);overflow:hidden;display:flex;align-items:flex-end;padding:clamp(18px,2vw,34px);border:2px solid #1d1d1d;background:#fff;opacity:0;transform:translateY(26px);transition:transform .5s var(--ease),opacity .5s var(--ease),box-shadow .4s var(--ease)}
.rbe-menu-open .rbe-menu__card{opacity:1;transform:none}
.rbe-menu__card:hover{box-shadow:0 24px 50px rgba(0,0,0,.28)}
.rbe-menu__card:hover .rbe-menu__bg{transform:scale(1.06)}
.rbe-menu__card--projecten{grid-column:1;grid-row:1 / 3;align-items:center;justify-content:center}
.rbe-menu__card--diensten{grid-column:2 / 4;grid-row:1}
.rbe-menu__card--over{grid-column:2;grid-row:2}
.rbe-menu__card--contact{grid-column:3;grid-row:2}
.rbe-menu__bgwrap{position:absolute;inset:0;overflow:hidden}
.rbe-menu__bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.45;transition:transform .6s var(--ease),opacity .4s var(--ease)}
.rbe-menu__scrim{position:absolute;inset:0;background:rgba(255,255,255,.06);transition:background .4s var(--ease)}
.rbe-menu__card:hover .rbe-menu__scrim{background:rgba(227,6,19,.5)}
.rbe-menu__card:hover .rbe-menu__bg{opacity:.6}
.rbe-menu__label{position:relative;z-index:2;font-family:var(--font-display);font-weight:700;color:var(--rbe-red);font-size:clamp(20px,2.4vw,40px);letter-spacing:.02em;transition:color .4s var(--ease)}
.rbe-menu__card:hover .rbe-menu__label{color:#fff}
.rbe-menu__label--vert{writing-mode:vertical-rl;transform:rotate(180deg);font-size:clamp(30px,3.4vw,58px)}
.rbe-menu-open .rbe-menu__card--projecten{transition-delay:.05s}
.rbe-menu-open .rbe-menu__card--diensten{transition-delay:.12s}
.rbe-menu-open .rbe-menu__card--over{transition-delay:.19s}
.rbe-menu-open .rbe-menu__card--contact{transition-delay:.26s}
/* ---- Gedeelde footer-balk (site-footer + onderaan bento-menu) ---- */
.rbe-footerbar{background:var(--rbe-red);color:#fff;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;padding:22px clamp(20px,4vw,60px)}
.rbe-footerbar__logo{display:inline-flex;flex:0 0 auto}
.rbe-footerbar__logo img{height:42px;width:auto}
.rbe-footerbar__links{display:flex;align-items:center;gap:22px;flex-wrap:wrap;font-family:var(--font-display);font-weight:500;color:#fff;letter-spacing:.04em}
.rbe-footerbar__links a{position:relative}
.rbe-footerbar__links a::after{content:"";position:absolute;left:0;bottom:-4px;width:100%;height:2px;background:#fff;transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease)}
.rbe-footerbar__links a:hover::after{transform:scaleX(1)}
.rbe-menu .rbe-footerbar{flex:0 0 auto;border-radius:var(--rbe-radius) var(--rbe-radius) 0 0;margin:0 calc(-1 * clamp(20px,4vw,64px))}
/* Site-footer: content voorbij de verticale titel-sidebar */
.rbe-footer .rbe-footerbar{padding-left:calc(var(--label-w) + clamp(20px,4vw,60px))}
/* Site-footer als losse witte balk met rode tekst (gesplitst van de achtergrond) */
.rbe-footerbar--site{background:var(--rbe-white);color:var(--rbe-red);border-top:3px solid var(--rbe-red)}
/* Witte woordmerk op een rode plaat, zodat het volledige logo leesbaar blijft op de witte balk */
.rbe-footerbar--site .rbe-footerbar__logo{background:var(--rbe-red);border-radius:14px;padding:11px 18px;display:inline-flex;align-items:center}
.rbe-footerbar--site .rbe-footerbar__logo img{height:30px;width:auto}
.rbe-footerbar--site .rbe-footerbar__links{color:var(--rbe-red)}
.rbe-footerbar--site .rbe-footerbar__links a::after{background:var(--rbe-red)}

/* ============================================================
   HOME / PROJECTEN — honingraat rond ReBrand
   ============================================================ */
/* Schermhoog + VERTICAAL gecentreerd. Door de symmetrische kolom-stagger valt het clustermidden
   samen met de centrale ReBrand-tegel, dus die staat altijd verticaal exact in het midden, ongeacht
   het aantal projecten. Links en rechts evenveel padding (label-breedte + gap) zodat de linkerkolom
   niet achter de verticale PROJECTEN-banner valt én het cluster echt gecentreerd oogt. */
.rbe-projects{position:relative;background:var(--rbe-red);overflow:hidden;box-sizing:border-box;min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:clamp(40px,7vh,96px) calc(var(--label-w) + clamp(8px,1vw,20px)) clamp(40px,7vh,96px) calc(var(--label-w) + clamp(8px,1vw,20px))}
.rbe-grid{display:flex;justify-content:center;align-items:flex-start;gap:var(--gap,28px)}
.rbe-col{display:flex;flex-direction:column;gap:var(--gap,28px);flex:0 0 auto;width:var(--T,300px)}
.rbe-col--mid{margin-top:calc((var(--T,300px) + var(--gap,28px)) / 2)}
.rbe-col--right{margin-top:calc(var(--T,300px) + var(--gap,28px))}

.rbe-tile{position:relative;width:var(--T,260px);height:var(--T,260px);flex:0 0 auto;background:var(--tile,#caa0e8);border-radius:26px;display:flex;align-items:center;justify-content:center;overflow:hidden;will-change:transform;transition:transform .45s var(--ease),box-shadow .45s var(--ease)}
.rbe-tile--empty{background:transparent;pointer-events:none;box-shadow:none}
.rbe-tile__logo{display:flex;align-items:center;justify-content:center;width:64%;height:64%;transition:transform .45s var(--ease),opacity .35s var(--ease)}
.rbe-tile__logo img{max-width:100%;max-height:100%;object-fit:contain}
.rbe-tile__logo--white img{filter:brightness(0) invert(1)}
.rbe-tile__reveal{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;opacity:0;transition:opacity .4s var(--ease)}
.rbe-tile__hero{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transform:scale(1.08);transition:transform .55s var(--ease)}
.rbe-tile__meta{position:relative;z-index:2;padding:13px 14px;background:linear-gradient(0deg,rgba(0,0,0,.62),rgba(0,0,0,0));color:#fff}
.rbe-tile__reveal--center .rbe-tile__meta{background:rgba(0,0,0,.45);border-radius:inherit;height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center}
.rbe-tile__title{display:block;font-family:var(--font-display);font-weight:700;font-size:clamp(13px,1.05vw,18px);line-height:1.05}
.rbe-tile__cat{display:block;font-size:.72rem;letter-spacing:.05em;opacity:.92;margin-top:3px;text-transform:uppercase}
.rbe-tile:not(.rbe-tile--empty):hover{transform:scale(1.06);box-shadow:0 22px 54px rgba(0,0,0,.36);z-index:6}
.rbe-tile:hover .rbe-tile__reveal{opacity:1}
.rbe-tile:hover .rbe-tile__hero{transform:scale(1)}
.rbe-tile:hover .rbe-tile__logo{transform:scale(.86);opacity:0}
/* Centrale tegel: zachte schaduw zodat hij als kaart leesbaar blijft op elke achtergrond (ook wit-op-wit). */
.rbe-tile--center{box-shadow:0 14px 44px rgba(0,0,0,.14)}

/* ============================================================
   PROJECT DETAIL (CASE)
   ============================================================ */
.rbe-case{position:relative;min-height:100vh;padding:calc(var(--topbar-h) + 20px) clamp(20px,4vw,60px) 80px calc(var(--label-w) + clamp(16px,2vw,40px))}
.rbe-case__inner{max-width:none;display:grid;gap:clamp(24px,3vw,48px)}
.rbe-case__showcase{background:#0e1c2b;border-radius:var(--rbe-radius-lg);overflow:hidden;aspect-ratio:16/9;display:flex;align-items:center;justify-content:center}
.rbe-case__showcase img{width:100%;height:100%;object-fit:cover}
.rbe-case__title{font-size:clamp(34px,5vw,68px);color:var(--rbe-red)}
.rbe-case__cat{font-family:var(--font-display);font-weight:500;letter-spacing:.05em;color:var(--rbe-muted);margin:.4em 0 0;text-transform:uppercase;font-size:.95rem}
.rbe-case__label{color:var(--rbe-red);font-size:clamp(20px,2vw,28px);margin-bottom:.4em}
.rbe-back{display:inline-block;font-family:var(--font-display);font-weight:500;color:var(--rbe-red);letter-spacing:.03em}

/* Projectsecties */
.rbe-sections{display:grid;gap:clamp(40px,6vh,90px);margin-top:clamp(30px,5vh,70px)}
.rbe-sec--split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,3vw,56px);align-items:center}
.rbe-sec--split.rbe-sec--reverse .rbe-sec__media{order:2}
.rbe-sec__media{margin:0}
.rbe-sec__media img{width:100%;border-radius:var(--rbe-radius);display:block}
.rbe-sec--full img{width:100%;border-radius:var(--rbe-radius-lg);display:block}
.rbe-sec__title{color:var(--rbe-red);font-size:clamp(24px,3vw,40px);margin-bottom:.5em}
.rbe-sec--heading .rbe-sec__heading{color:var(--rbe-red);font-size:clamp(30px,4.4vw,60px)}
.rbe-sec__list{list-style:none;padding:0;margin:0;display:grid;gap:12px}
.rbe-sec__list li{position:relative;padding-left:32px;font-size:1.05rem}
.rbe-sec__list li::before{content:"";position:absolute;left:0;top:.45em;width:15px;height:15px;background:var(--rbe-red);clip-path:polygon(50% 0,100% 50%,50% 100%,0 50%)}
@media(max-width:680px){
	.rbe-sec--split,.rbe-sec--split.rbe-sec--reverse{grid-template-columns:1fr}
	.rbe-sec--split.rbe-sec--reverse .rbe-sec__media{order:0}
}

/* ============================================================
   OVER ONS
   ============================================================ */
.rbe-over{position:relative;min-height:100vh;padding:calc(var(--topbar-h) + 20px) clamp(20px,4vw,60px) 80px calc(var(--label-w) + clamp(16px,2vw,40px))}
.rbe-over__inner{max-width:none;display:grid;gap:clamp(40px,6vh,80px)}
.rbe-over__block{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(24px,3vw,56px);align-items:center}
.rbe-over__block--reverse{grid-template-columns:1.15fr .85fr}
.rbe-over__block--reverse .rbe-over__photo{order:2}
.rbe-over__title{color:var(--rbe-red);font-size:clamp(30px,3.4vw,48px);margin-bottom:.5em}
.rbe-over__photo img{width:100%;border-radius:var(--rbe-radius)}
.rbe-over__photo--framed{position:relative}
.rbe-over__photo--framed::before{content:"";position:absolute;inset:-18px -18px auto -18px;height:60%;background:var(--rbe-red);border-radius:var(--rbe-radius);clip-path:polygon(0 0,100% 0,100% 70%,50% 100%,0 70%);z-index:-1}

/* ============================================================
   CONTACT / QUICKSCAN — rood paneel op wit
   ============================================================ */
.rbe-contact{position:relative;min-height:100vh;background:#fff}
.rbe-contact__panel{position:relative;color:#fff;background:var(--rbe-red);margin:calc(var(--topbar-h) + 10px) clamp(16px,2vw,40px) 50px var(--label-w);padding:clamp(34px,6vh,70px) clamp(28px,4vw,64px) clamp(64px,11vh,128px);border-radius:20px 20px 0 0;clip-path:polygon(0 0,100% 0,100% 88%,93% 100%,57% 100%,50% 93%,43% 100%,7% 100%,0 88%)}
.rbe-contact__mark{position:absolute;right:clamp(14px,3vw,44px);bottom:clamp(30px,7vh,80px);width:clamp(64px,8vw,110px);opacity:.95}
.rbe-contact__lead{font-family:var(--font-body);font-weight:400;font-size:clamp(20px,2.6vw,38px);margin:0 0 .1em}
.rbe-contact__title{font-size:clamp(30px,5vw,64px);margin:0 0 .8em;color:#fff}
.rbe-form{display:grid;gap:clamp(14px,2vh,22px);max-width:none}
.rbe-form__row{display:grid;gap:8px}
.rbe-form__row label{font-weight:500;font-size:1.05rem}
.rbe-form input[type=text],.rbe-form input[type=email],.rbe-form input[type=url]{width:100%;border:0;border-radius:18px;padding:18px 22px;font:inherit;background:#fff;color:var(--rbe-ink)}
.rbe-form input:focus{outline:3px solid rgba(255,255,255,.6);outline-offset:2px}
.rbe-hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.rbe-form__consent{display:flex;gap:10px;font-size:.92rem;margin-top:4px}
.rbe-form__consent input{margin-top:4px}
.rbe-form__consent a{text-decoration:underline}
.rbe-formmsg{font-weight:600;padding:14px 20px;border-radius:16px;max-width:none}
.rbe-formmsg--ok{background:#fff;color:#1a7a1a}
.rbe-formmsg--err{background:#fff;color:var(--rbe-red)}

/* ---- Buttons ---- */
.rbe-btn{display:inline-block;font-family:var(--font-display);font-weight:500;letter-spacing:.04em;background:#fff;color:var(--rbe-red);padding:16px 34px;border-radius:16px;align-self:start;transition:transform .35s var(--ease),box-shadow .35s var(--ease)}
.rbe-btn:hover{transform:translateY(-3px);box-shadow:0 16px 30px rgba(0,0,0,.25)}
.rbe-btn--dark{background:var(--rbe-red);color:#fff}

/* ============================================================
   DIENSTEN
   ============================================================ */
.rbe-diensten{position:relative;min-height:100vh;padding:calc(var(--topbar-h) + 20px) clamp(20px,4vw,60px) 80px calc(var(--label-w) + clamp(16px,2vw,40px))}
.rbe-diensten__inner{max-width:none;display:grid;gap:28px}
.rbe-diensten__title{color:var(--rbe-red);font-size:clamp(34px,5vw,64px)}
.rbe-diensten__cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:10px}
.rbe-diensten__card{border:2px solid var(--rbe-red);border-radius:var(--rbe-radius);padding:28px;background:#fff}
.rbe-diensten__card h3{color:var(--rbe-red);font-size:1.4rem;margin-bottom:.5em}

/* ---- Generic page ---- */
.rbe-page{padding:calc(var(--topbar-h) + 30px) clamp(20px,4vw,60px) 80px}
.rbe-page__inner,.rbe-richtext{max-width:none}
.rbe-richtext p{margin:0 0 1em}

/* ============================================================
   FOOTER
   ============================================================ */
.rbe-footer{display:block}

/* ---- Page transition curtain (standaard dekkend, lift via CSS -> geen flikker) ---- */
.rbe-curtain{position:fixed;inset:0;background:var(--rbe-red);z-index:100001;transform:translateY(0);pointer-events:none;will-change:transform;animation:rbe-curtain-reveal .7s var(--ease) .05s forwards}
@keyframes rbe-curtain-reveal{from{transform:translateY(0)}to{transform:translateY(-100%)}}
@media(prefers-reduced-motion:reduce){.rbe-curtain{animation:none;transform:translateY(-100%)}}

/* ---- WIE edit-mode safety ---- */
.wie-edit-active .rbe-tile__reveal{opacity:1!important}
.wie-edit-active [data-wie-field]{transition:none!important}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
	:root{--label-w:64px;--topbar-h:80px}
	.rbe-vlabel{font-size:24px}
}
@media(max-width:680px){
	:root{--label-w:0px;--topbar-h:72px}
	.rbe-vlabel{display:none}
	.rbe-case,.rbe-over,.rbe-contact,.rbe-diensten{padding-left:clamp(16px,4vw,24px);padding-right:clamp(16px,4vw,24px)}
	.rbe-over__block,.rbe-over__block--reverse{grid-template-columns:1fr}
	.rbe-over__block--reverse .rbe-over__photo{order:0}
	.rbe-diensten__cards{grid-template-columns:1fr}
	.rbe-footer__inner{flex-direction:column;align-items:flex-start}
	.rbe-menu__bento{grid-template-columns:1fr 1fr;grid-template-rows:repeat(3,1fr)}
	.rbe-menu__card--projecten{grid-column:1 / 3;grid-row:1;align-items:flex-end;justify-content:flex-start}
	.rbe-menu__card--diensten{grid-column:1 / 3;grid-row:2}
	.rbe-menu__card--over{grid-column:1;grid-row:3}
	.rbe-menu__card--contact{grid-column:2;grid-row:3}
	.rbe-menu__label--vert{writing-mode:horizontal-tb;transform:none}
}

/* ---- Reduced motion ---- */
@media(prefers-reduced-motion:reduce){
	*{animation-duration:.001ms!important;transition-duration:.001ms!important}
	.lenis.lenis-smooth{scroll-behavior:auto!important}
}
