/* Nieuwe Waarde — portfolio site
   Styling: Soft Grid baseline + themes + larger modal logo + subtler world map
            + SNW bridge + contact form + theme-driven accent colors. */

:root{
  --ink:#15151c;
  --ink-soft:#4a4a58;      /* slightly darker than v1 for better contrast */
  --ink-mute:#7a7a86;
  --paper:#ffffff;
  --paper-warm:#faf8f5;
  --paper-deep:#f3efe7;
  --hair:#ece9e3;
  --hair-strong:#d8d4cc;

  /* NW muted stichting palette */
  --c1:#c16847; /* food           – oranje  */
  --c2:#7a9a88; /* nature         – groen   */
  --c3:#6b5980; /* science        – paars   */
  --c4:#c15f72; /* mobility       – roze    */
  --c5:#c9a85e; /* health         – goud    */
  --c6:#3c7b93; /* climate        – blauw   */

  --max:1280px;
  --radius:14px;
  --radius-sm:10px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Poppins",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  font-weight:300;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
body.modal-open{overflow:hidden}
a{color:inherit}
img{max-width:100%;display:block}

.wrap{max-width:var(--max);margin:0 auto;padding:0 40px}
@media(max-width:640px){.wrap{padding:0 22px}}

/* ================= nav ================= */
nav.top{
  position:sticky;top:0;z-index:20;
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--hair);
}
nav.top .inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 40px;max-width:var(--max);margin:0 auto;gap:20px;
}
nav.top .brand{display:flex;align-items:center;gap:14px;text-decoration:none;color:inherit}
nav.top .brand .mark{width:34px;height:34px}
nav.top .brand .wordmark{font-weight:500;letter-spacing:.005em;font-size:17px}
nav.top .brand .suffix{
  display:inline-block;margin-left:8px;
  color:var(--ink-mute);font-weight:400;font-size:13px;letter-spacing:.08em;
  transform:translateY(-2px);
}
nav.top ul{list-style:none;display:flex;gap:24px;margin:0;padding:0;font-size:13px;color:var(--ink-soft)}
nav.top ul a{color:inherit;text-decoration:none;padding:4px 0}
nav.top ul a:hover{color:var(--ink)}
@media(max-width:860px){nav.top ul{display:none}}
@media(max-width:640px){
  nav.top .inner{padding:14px 22px;gap:12px}
  nav.top .brand .wordmark{font-size:15px}
}

/* ================= hero ================= */
.hero{padding:96px 0 40px;position:relative}
.hero .kicker{
  display:inline-flex;align-items:center;gap:10px;
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-soft);margin-bottom:24px;
}
.hero .kicker::before{content:"";width:30px;height:1px;background:var(--ink-soft)}
.hero h1{
  font-weight:300;font-size:clamp(38px,6vw,76px);line-height:1.05;
  letter-spacing:-.015em;margin:0 0 22px;max-width:900px;color:var(--ink);
}
.hero h1 b{font-weight:500;color:var(--c3)}
.hero .lede{max-width:680px;font-size:17px;color:var(--ink-soft);line-height:1.65}
.hero .stripe{display:flex;gap:5px;margin-top:48px;width:260px;height:5px}
.hero .stripe i{flex:1;border-radius:3px}
.hero .stripe i:nth-child(1){background:var(--c1)}
.hero .stripe i:nth-child(2){background:var(--c2)}
.hero .stripe i:nth-child(3){background:var(--c5)}
.hero .stripe i:nth-child(4){background:var(--c6)}
.hero .stripe i:nth-child(5){background:var(--c3)}
.hero .stripe i:nth-child(6){background:var(--c4)}
@media(max-width:640px){.hero{padding:64px 0 28px}.hero .lede{font-size:16px}}

/* ================= stats ================= */
.stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:28px;
  padding:48px 0;border-top:1px solid var(--hair);border-bottom:1px solid var(--hair);
  margin:20px 0 64px;
}
.stats > div{display:flex;flex-direction:column;gap:6px;position:relative;padding-left:16px}
.stats > div::before{
  content:"";position:absolute;left:0;top:10px;width:6px;height:6px;border-radius:50%;
}
.stats > div:nth-child(1)::before{background:var(--c1)}
.stats > div:nth-child(2)::before{background:var(--c6)}
.stats > div:nth-child(3)::before{background:var(--c2)}
.stats > div:nth-child(4)::before{background:var(--c5)}
.stats .n{font-size:34px;font-weight:300;letter-spacing:-.02em;color:var(--ink)}
.stats .l{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute)}
@media(max-width:720px){.stats{grid-template-columns:repeat(2,1fr);gap:22px;padding:32px 0;margin:16px 0 48px}}

/* ================= sections ================= */
.section{padding:48px 0 24px}
.section-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:36px;gap:20px;flex-wrap:wrap}
.section-head .left{display:flex;align-items:baseline;gap:16px}
.section-head h2{font-weight:400;font-size:30px;margin:0;letter-spacing:-.005em;color:var(--ink)}
.section-head .accent{width:32px;height:4px;border-radius:2px;background:var(--c3);margin-right:6px;display:inline-block;transform:translateY(-5px)}
.section-head.funds .accent{background:var(--c6)}
.section-head.themes .accent{background:var(--c5)}
.section-head.approach .accent{background:var(--c2)}
.section-head.contact .accent{background:var(--c4)}
.section-head .desc{font-size:14px;color:var(--ink-soft);max-width:520px}

/* ================= grid (portfolio tiles) ================= */
.grid{display:grid;grid-template-columns:repeat(6,1fr);gap:20px}
@media(max-width:1100px){.grid{grid-template-columns:repeat(4,1fr)}}
@media(max-width:720px){.grid{grid-template-columns:repeat(2,1fr);gap:14px}}

.tile{
  position:relative;aspect-ratio:1/1;
  background:var(--paper);border:1px solid var(--hair);border-radius:var(--radius);
  display:flex;align-items:center;justify-content:center;
  padding:18px 18px 30px;overflow:hidden;cursor:pointer;
  transition:transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s, border-color .35s;
  appearance:none;font:inherit;color:inherit;text-align:left;
}
.tile:focus-visible{outline:2px solid var(--c6);outline-offset:3px}
.tile:hover{transform:translateY(-4px);border-color:var(--hair-strong);box-shadow:0 18px 40px -20px rgba(21,21,28,.2)}
.tile .logo{max-width:78%;max-height:60%;object-fit:contain;filter:saturate(.8)}
.tile .fallback{font-weight:500;font-size:22px;letter-spacing:.01em;color:var(--ink-soft)}

/* theme-driven accent bar */
.tile .accent-bar{
  position:absolute;top:0;left:0;right:0;height:5px;opacity:.6;transition:opacity .35s, height .35s;
  background:var(--tile-color, var(--c3));
}
.tile:hover .accent-bar{opacity:.82;height:6px}
/* fallback bar colors when no theme is set */
.tile[data-theme-color=""]:nth-child(6n+1) .accent-bar{background:var(--c1)}
.tile[data-theme-color=""]:nth-child(6n+2) .accent-bar{background:var(--c2)}
.tile[data-theme-color=""]:nth-child(6n+3) .accent-bar{background:var(--c3)}
.tile[data-theme-color=""]:nth-child(6n+4) .accent-bar{background:var(--c4)}
.tile[data-theme-color=""]:nth-child(6n+5) .accent-bar{background:var(--c5)}
.tile[data-theme-color=""]:nth-child(6n+6) .accent-bar{background:var(--c6)}

/* tile name label */
.tile .tile-label{
  position:absolute;bottom:9px;left:0;right:0;
  text-align:center;font-size:12px;font-weight:300;letter-spacing:.03em;
  color:var(--ink-mute);
  transition:color .25s;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  padding:0 10px;
}
.tile:hover .tile-label{color:var(--ink)}

/* warm band: only behind the card grid, title stays above */
#direct .grid, #funds .grid{
  background:linear-gradient(to right, #f0ece5, #f6f3ee 50%, #f0ece5);
  border-radius:14px;
  padding:28px;
  margin-top:0;
}
@media(max-width:640px){
  #direct .grid, #funds .grid{padding:18px;border-radius:10px}
}

/* ================= themes strip ================= */
.themes{padding-top:56px}
.themes .intro{max-width:680px;color:var(--ink-soft);margin:0 0 36px;font-size:16px}
.theme-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;
}
@media(max-width:900px){.theme-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:540px){.theme-grid{grid-template-columns:1fr}}
.theme-card{
  background:var(--paper-warm);border:1px solid var(--hair);border-radius:var(--radius);
  padding:22px 22px 20px;position:relative;overflow:hidden;
}
.theme-card::before{
  content:"";position:absolute;top:0;left:0;bottom:0;width:4px;
  background:var(--theme-color, var(--c3));
}
.theme-card h3{
  font-size:15px;font-weight:500;letter-spacing:.01em;margin:0 0 6px;color:var(--ink);
  display:flex;align-items:center;gap:10px;
}
.theme-card h3 .dot{width:10px;height:10px;border-radius:50%;background:var(--theme-color, var(--c3));display:inline-block}
.theme-card p{font-size:13.5px;color:var(--ink-soft);line-height:1.55;margin:0}

/* ================= approach / about ================= */
.approach{padding-top:72px}
.about-body{
  display:grid;grid-template-columns:1fr 1fr;gap:60px;
  max-width:980px;
}
.about-body p{font-size:16px;color:var(--ink-soft);margin:0 0 1em;line-height:1.7}
.about-body p:first-child{color:var(--ink);font-size:18px}
@media(max-width:800px){.about-body{grid-template-columns:1fr;gap:0}}

.signoff{
  margin-top:32px;max-width:980px;padding-top:24px;border-top:1px solid var(--hair);
  font-size:13px;color:var(--ink-mute);letter-spacing:.04em;
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
}
.signoff .name{color:var(--ink);font-weight:500}
.signoff a{color:inherit;text-decoration:none}
.signoff .linkedin{
  display:inline-flex;align-items:center;justify-content:center;
  width:22px;height:22px;border-radius:4px;color:var(--ink-soft);
  transition:color .25s, transform .2s;
}
.signoff .linkedin:hover{color:var(--c6);transform:translateY(-1px)}

/* ================= bridge to SNW ================= */
.bridge{
  margin-top:72px;padding:28px 30px;
  background:var(--paper-warm);border:1px solid var(--hair);border-radius:var(--radius);
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:28px;
}
.bridge .bridge-logo{
  flex-shrink:0;width:180px;
}
.bridge .bridge-logo svg,
.bridge .bridge-logo img{width:100%;height:auto;display:block}
.bridge .bridge-text{color:var(--ink-soft);font-size:14.5px;line-height:1.65}
.bridge .bridge-text h4{margin:0 0 4px;font-weight:500;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-mute)}
.bridge .bridge-text p{margin:0;color:var(--ink)}
.bridge a.bridge-cta{
  text-decoration:none;color:var(--ink);font-weight:500;font-size:13px;
  letter-spacing:.04em;border:1px solid var(--hair-strong);border-radius:99px;
  padding:10px 18px;transition:color .25s, border-color .25s, background .25s;white-space:nowrap;
}
.bridge a.bridge-cta:hover{color:#fff;background:var(--c1);border-color:var(--c1)}
@media(max-width:860px){
  .bridge{grid-template-columns:1fr;text-align:left}
  .bridge .bridge-logo{width:140px}
  .bridge a.bridge-cta{justify-self:start}
}

/* ================= contact ================= */
.contact{padding-top:56px}
.contact-body{
  display:grid;grid-template-columns:1fr 1fr;gap:56px;max-width:980px;align-items:start;
}
@media(max-width:800px){.contact-body{grid-template-columns:1fr;gap:24px}}
.contact-body .intro{color:var(--ink-soft);font-size:16px;line-height:1.7}
.contact-greeting{
  margin:0 0 10px;font-size:15px;color:var(--ink);line-height:1.55;
  letter-spacing:.01em;font-weight:500;
}
.contact-form input[readonly]{
  background:var(--paper-warm);color:var(--ink-soft);cursor:not-allowed;
}

.contact-form{display:flex;flex-direction:column;gap:14px}
.contact-form label{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:4px}
.contact-form input,
.contact-form textarea{
  width:100%;font:inherit;font-size:15px;color:var(--ink);
  background:var(--paper);border:1px solid var(--hair-strong);border-radius:var(--radius-sm);
  padding:12px 14px;transition:border-color .25s, box-shadow .25s;
}
.contact-form input:focus,
.contact-form textarea:focus{
  outline:none;border-color:var(--c6);box-shadow:0 0 0 3px rgba(60,123,147,.15);
}
.contact-form textarea{min-height:120px;resize:vertical;font-family:inherit}
.contact-form button{
  align-self:flex-start;
  background:var(--ink);color:#fff;border:none;font:inherit;
  padding:12px 26px;border-radius:99px;cursor:pointer;
  font-size:14px;letter-spacing:.02em;
  transition:background .25s, transform .2s;
}
.contact-form button:hover{background:var(--c6);transform:translateY(-1px)}
.contact-form .thanks{
  padding:14px 16px;background:var(--paper-warm);border-left:3px solid var(--c2);
  color:var(--ink);font-size:14px;line-height:1.6;border-radius:var(--radius-sm);
}

/* ================= footer ================= */
footer{margin-top:120px;padding:56px 0 48px;background:var(--paper-warm);border-top:1px solid var(--hair)}
footer .foot{
  display:grid;grid-template-columns:auto 1fr;gap:16px 28px;align-items:center;
}
footer .brand{display:flex;align-items:center;gap:12px;font-weight:500;font-size:14px}
footer .brand .suffix{color:var(--ink-mute);font-weight:400;margin-left:6px;font-size:12px;letter-spacing:.08em}
footer .note{grid-column:1 / -1;font-size:12px;color:var(--ink-mute);max-width:720px;line-height:1.7}
footer .copy{grid-column:1 / -1;font-size:11px;color:var(--ink-mute);letter-spacing:.06em;padding-top:20px;border-top:1px solid var(--hair);margin-top:8px}
@media(max-width:720px){footer .foot{grid-template-columns:1fr}}

/* ================= modal ================= */
.modal{position:fixed;inset:0;z-index:50;display:flex;align-items:center;justify-content:center;padding:20px}
.modal[hidden]{display:none}
.modal-backdrop{position:absolute;inset:0;background:rgba(21,21,28,.58);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);animation:fade .25s ease}
.modal-card{
  position:relative;z-index:1;width:min(720px,100%);
  background:var(--paper);border-radius:18px;border:1px solid var(--hair);
  box-shadow:0 40px 80px -30px rgba(21,21,28,.45);
  padding:40px 40px 32px;max-height:calc(100vh - 40px);overflow:auto;
  animation:rise .28s cubic-bezier(.2,.7,.2,1);
  border-top:4px solid var(--modal-color, var(--c3));
}
@media(max-width:640px){.modal-card{padding:28px 22px 24px;border-radius:14px}}
.modal-close{
  position:absolute;top:14px;right:14px;
  width:36px;height:36px;border-radius:50%;background:transparent;
  border:1px solid var(--hair);color:var(--ink-soft);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:color .25s, border-color .25s, background .25s;
}
.modal-close:hover{color:var(--ink);border-color:var(--ink);background:var(--paper-warm)}

.modal-head{display:flex;gap:26px;align-items:center;margin-top:0;margin-bottom:0}
.modal-logo{
  flex:0 0 190px;width:190px;height:190px;border-radius:var(--radius);
  background:#fff;
  display:flex;align-items:center;justify-content:center;padding:22px;overflow:hidden;
}
.modal-logo img{max-width:100%;max-height:100%;object-fit:contain;filter:saturate(.9)}
.modal-logo .fallback{font-weight:500;font-size:42px;color:var(--ink-soft)}
@media(max-width:640px){.modal-logo{flex:0 0 110px;width:110px;height:110px;padding:12px}.modal-logo .fallback{font-size:28px}}

.modal-id{min-width:0;flex:1}
.modal-id .eyebrow{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--modal-color, var(--ink-mute));margin-bottom:6px;font-weight:500}
.modal-id h3{font-weight:400;font-size:28px;letter-spacing:-.01em;margin:0 0 10px;line-height:1.1;color:var(--ink)}
.modal-id .meta-row{font-size:13px;color:var(--ink-soft);display:flex;flex-wrap:wrap;gap:8px}
.modal-id .dot-sep{color:var(--ink-mute)}

/* world map — subtle, supporting */
.modal-map{
  margin:20px 0 0;width:100%;aspect-ratio:2/1;max-height:190px;
  background:var(--paper-warm);border:1px solid var(--hair);border-radius:var(--radius-sm);
  overflow:hidden;position:relative;opacity:.85;
}
.modal-map svg{display:block;width:100%;height:100%}
.modal-map .map-dot{
  pointer-events:none;
}
.modal-map .map-dot circle.pulse{opacity:.2}
.modal-map .map-dot circle.core{opacity:.95}

.modal-summary{
  font-size:15px;color:var(--ink);line-height:1.7;margin:0 0 22px;
}
.modal-summary p{margin:0 0 0.9em}

.modal-foot{display:flex;justify-content:flex-end;gap:10px;border-top:1px solid var(--hair);padding-top:18px}
.ghost-btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:9px 18px;border:1px solid var(--hair-strong);border-radius:99px;
  text-decoration:none;color:var(--ink);font-size:13px;letter-spacing:.02em;
  transition:background .25s, border-color .25s, color .25s;
}
.ghost-btn:hover{background:var(--modal-color, var(--ink));color:#fff;border-color:var(--modal-color, var(--ink))}

@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes rise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

@media (prefers-reduced-motion:reduce){
  *{animation:none !important;transition:none !important;scroll-behavior:auto !important}
}

/* ================================================================
   Email gate (pre-login): landing / register / code / thanks
   ================================================================ */
html.gate-lock, html.gate-lock body{overflow:hidden;height:100vh}

.gate{
  position:fixed;inset:0;z-index:80;
  display:flex;align-items:center;justify-content:center;
  padding:24px;
  background:radial-gradient(1200px 800px at 30% -10%, #fbf6ee, #ffffff 60%),
             linear-gradient(180deg, #ffffff, #faf8f5);
  overflow:auto;
}
.gate[hidden]{display:none !important}

.gate-card{
  position:relative;z-index:1;
  width:min(560px, 100%);
  background:#ffffff;border:1px solid var(--hair);
  border-radius:20px;
  box-shadow:0 40px 80px -40px rgba(21,21,28,.18), 0 6px 20px -12px rgba(21,21,28,.08);
  padding:36px 44px 28px;
  animation:gateRise .5s cubic-bezier(.2,.7,.2,1);
}
.gate-card .register-card,
.gate-card .code-card,
.gate-card .thanks-card{animation:gateFade .35s ease}
.gate-card .logo-row{display:flex;justify-content:flex-start;margin-bottom:18px}
.gate-card .logo-row img{width:56px;height:56px}
.gate-card .wordmark{
  text-align:left;font-weight:500;font-size:19px;letter-spacing:.005em;color:var(--ink);
  margin-bottom:28px;
}
.gate-card .wordmark .suffix{
  display:inline-block;margin-left:8px;
  color:var(--ink-mute);font-weight:400;font-size:13px;letter-spacing:.08em;
  transform:translateY(-2px);
}
.gate-card .stripe{
  display:flex;gap:4px;margin:32px auto 0;width:150px;height:4px;
}
.gate-card .stripe i{flex:1;border-radius:3px;display:block}
.gate-card .stripe i:nth-child(1){background:var(--c1)}
.gate-card .stripe i:nth-child(2){background:var(--c2)}
.gate-card .stripe i:nth-child(3){background:var(--c5)}
.gate-card .stripe i:nth-child(4){background:var(--c6)}
.gate-card .stripe i:nth-child(5){background:var(--c3)}
.gate-card .stripe i:nth-child(6){background:var(--c4)}

.gate-view[hidden]{display:none !important}

/* landing */
.gate-landing .intro-1{
  text-align:left;color:var(--ink);font-size:17px;line-height:1.55;margin:0 0 4px;font-weight:400;
}
.gate-landing .intro-2{
  text-align:left;color:var(--ink-soft);font-size:14.5px;line-height:1.55;margin:0 0 28px;
}
.gate-form{display:flex;flex-direction:column;gap:14px}
.gate-form label{
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-mute);
}
.gate-form input[type="email"]{
  width:100%;font:inherit;font-size:15.5px;color:var(--ink);
  background:var(--paper);border:1px solid var(--hair-strong);border-radius:var(--radius-sm);
  padding:14px 16px;transition:border-color .25s, box-shadow .25s;
}
.gate-form input[type="email"]:focus{
  outline:none;border-color:var(--c6);box-shadow:0 0 0 3px rgba(60,123,147,.18);
}
.gate-form button{
  margin-top:6px;background:var(--ink);color:#fff;border:none;font:inherit;
  padding:14px 22px;border-radius:99px;cursor:pointer;
  font-size:14.5px;letter-spacing:.02em;
  transition:background .25s, transform .2s, box-shadow .25s;
  box-shadow:0 10px 24px -14px rgba(21,21,28,.5);
}
.gate-form button:hover{background:var(--c6);transform:translateY(-1px)}
.gate-form button:disabled{opacity:.88;cursor:wait;position:relative;overflow:hidden}
.register-card button.submit:disabled{opacity:.88;cursor:wait;position:relative;overflow:hidden}
.code-card .submit:disabled{opacity:.88;cursor:wait;position:relative;overflow:hidden}

.gate-form button:disabled::after,
.register-card button.submit:disabled::after,
.code-card .submit:disabled::after{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(
    90deg,
    transparent 0%,
    rgba(255,255,255,.12) 30%,
    rgba(255,255,255,.38) 50%,
    rgba(255,255,255,.12) 70%,
    transparent 100%
  );
  transform:translateX(-100%);
  animation:btnBeam 1.25s ease-in-out infinite alternate;
  pointer-events:none;
  will-change:transform;
}
@keyframes btnBeam{to{transform:translateX(100%)}}
.gate-form .footnote{
  margin:22px 0 0;font-size:12px;color:var(--ink-mute);line-height:1.6;text-align:left;
}
.gate-form .error-text,
.register-card .error-text,
.code-card .error-text{
  min-height:18px;color:#b04a4a;font-size:12.5px;line-height:1.4;text-align:center;margin-top:2px;
}

/* register */
.register-card h2{
  font-weight:400;font-size:23px;margin:0 0 10px;letter-spacing:-.005em;color:var(--ink);
  text-align:left;
}
.register-card .intro{
  font-size:14px;color:var(--ink-soft);line-height:1.65;margin:0 0 20px;
}
.register-form{display:grid;grid-template-columns:1fr 1fr;gap:14px 14px}
.register-form .full{grid-column:1 / -1}
.register-form label{
  display:block;font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:4px;
}
.register-form input{
  width:100%;font:inherit;font-size:14.5px;color:var(--ink);
  background:var(--paper);border:1px solid var(--hair-strong);border-radius:var(--radius-sm);
  padding:11px 13px;transition:border-color .25s, box-shadow .25s;
}
.register-form input:focus{
  outline:none;border-color:var(--c6);box-shadow:0 0 0 3px rgba(60,123,147,.18);
}
.register-form input.invalid{
  border-color:#c0625a;
}
.register-form input.invalid:focus{
  border-color:#c0625a;box-shadow:0 0 0 3px rgba(192,98,90,.18);
}
.register-form .hint{
  font-size:11px;color:var(--ink-mute);margin-top:4px;letter-spacing:0;text-transform:none;
}
.field-error{
  min-height:15px;font-size:11.5px;color:#b04a4a;
  line-height:1.4;margin-top:4px;letter-spacing:0;text-transform:none;
  font-weight:400;
}
.register-card .actions{
  display:flex;align-items:center;justify-content:space-between;margin-top:18px;gap:12px;
}
.register-card .back-link{
  background:none;border:none;padding:0;font:inherit;color:var(--ink-soft);
  font-size:13px;cursor:pointer;letter-spacing:.02em;
}
.register-card .back-link:hover{color:var(--ink)}
.register-card button.submit{
  background:var(--ink);color:#fff;border:none;font:inherit;
  padding:12px 22px;border-radius:99px;cursor:pointer;
  font-size:14px;letter-spacing:.02em;
  transition:background .25s, transform .2s;
}
.register-card button.submit:hover{background:var(--c6);transform:translateY(-1px)}

/* thanks */
.thanks-card{text-align:center}
.thanks-card .tick{
  width:56px;height:56px;border-radius:50%;background:rgba(122,154,136,.15);
  display:flex;align-items:center;justify-content:center;margin:0 auto 18px;
  color:var(--c2);
}
.thanks-card h2{font-weight:400;font-size:23px;margin:0 0 10px;color:var(--ink)}
.thanks-card p{color:var(--ink-soft);line-height:1.65;margin:0 0 24px;font-size:14.5px}
.thanks-card .close-btn{
  background:transparent;border:1px solid var(--hair-strong);color:var(--ink);
  font:inherit;padding:10px 22px;border-radius:99px;cursor:pointer;font-size:13px;
}
.thanks-card .close-btn:hover{background:var(--paper-warm)}

/* code */
.code-card h2{
  font-weight:400;font-size:23px;margin:0 0 6px;color:var(--ink);text-align:center;
}
.code-card .subtitle{
  text-align:center;color:var(--ink-soft);font-size:14px;line-height:1.5;margin:0 0 24px;
}
.code-cells{
  display:flex;justify-content:center;gap:10px;margin:8px 0 16px;
}
.code-cells input{
  width:48px;height:56px;text-align:center;font:inherit;font-size:22px;font-weight:500;
  color:var(--ink);letter-spacing:0;
  background:var(--paper);border:1px solid var(--hair-strong);border-radius:10px;
  transition:border-color .2s, box-shadow .2s;
}
.code-cells input:focus{
  outline:none;border-color:var(--c6);box-shadow:0 0 0 3px rgba(60,123,147,.18);
}
@media(max-width:480px){
  .code-cells input{width:40px;height:48px;font-size:18px}
  .code-cells{gap:7px}
}
.code-card .submit{
  width:100%;background:var(--ink);color:#fff;border:none;font:inherit;
  padding:13px 22px;border-radius:99px;cursor:pointer;font-size:14px;letter-spacing:.02em;
  transition:background .25s, transform .2s;margin-top:10px;
}
.code-card .submit:hover{background:var(--c6);transform:translateY(-1px)}
.code-card .link-row{
  display:flex;justify-content:space-between;gap:14px;margin-top:18px;
  font-size:13px;color:var(--ink-soft);
}
.code-card .link-row button{
  background:none;border:none;padding:0;font:inherit;color:var(--ink-soft);cursor:pointer;
}
.code-card .link-row button:hover{color:var(--ink)}
.code-card .session-note{
  margin:20px 0 0;font-size:12px;color:var(--ink-mute);text-align:center;line-height:1.5;
}

/* demo panel */
.demo-panel{
  position:fixed;bottom:12px;left:50%;transform:translateX(-50%);
  z-index:90;background:#15151c;color:#fff;
  border-radius:99px;padding:6px 10px;display:flex;gap:4px;flex-wrap:wrap;
  font-size:11px;letter-spacing:.02em;box-shadow:0 10px 30px -10px rgba(0,0,0,.4);
}
.demo-panel[hidden]{display:none !important}
.demo-panel .label{padding:4px 8px;color:rgba(255,255,255,.55);align-self:center}
.demo-panel button{
  background:rgba(255,255,255,.08);border:none;color:#fff;font:inherit;
  padding:5px 11px;border-radius:99px;cursor:pointer;transition:background .2s;
}
.demo-panel button:hover{background:rgba(255,255,255,.18)}
.demo-panel button.reset{background:rgba(193,95,114,.3)}
.demo-panel button.reset:hover{background:rgba(193,95,114,.6)}

@keyframes gateRise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
@keyframes gateFade{from{opacity:0}to{opacity:1}}

@media(max-width:520px){
  .gate{padding:14px}
  .gate-card{padding:28px 20px 22px}
  .register-form{grid-template-columns:1fr}
  .register-form .full{grid-column:auto}
}

/* ================================================================
   Curator (post-login "About Johan")
   ================================================================ */
.curator{padding-top:56px}
.curator-body{
  display:grid;grid-template-columns:auto 1fr;gap:36px;align-items:start;max-width:980px;
}
.curator-avatar{
  width:120px;height:120px;border-radius:50%;
  background:linear-gradient(135deg, #f3efe7 0%, #faf8f5 100%);
  border:1px solid var(--hair);
  display:flex;align-items:center;justify-content:center;
  position:relative;flex-shrink:0;overflow:hidden;
}
.curator-avatar::after{
  content:"";position:absolute;inset:-1px;border-radius:50%;padding:1px;
  background:conic-gradient(from 140deg, var(--c1), var(--c5), var(--c2), var(--c6), var(--c3), var(--c4), var(--c1));
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:.5;
}
.curator-avatar .monogram{
  font-size:40px;font-weight:300;letter-spacing:-.01em;color:var(--ink);
}
.curator-avatar .curator-photo{
  width:100%;height:100%;object-fit:cover;object-position:center top;
  border-radius:50%;display:block;
}
.curator-id .eyebrow{
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:6px;
}
.curator-id h3{
  font-weight:400;font-size:26px;margin:0 0 14px;color:var(--ink);letter-spacing:-.01em;
}
.curator-id p{
  font-size:15px;color:var(--ink-soft);line-height:1.7;margin:0 0 .9em;
}
.curator-id .linkedin-cta{
  display:inline-flex;align-items:center;gap:8px;
  margin-top:14px;padding:8px 16px;
  text-decoration:none;color:var(--ink);font-size:13px;letter-spacing:.02em;
  border:1px solid var(--hair-strong);border-radius:99px;
  transition:color .25s, border-color .25s, background .25s;
}
.curator-id .linkedin-cta:hover{
  color:#fff;background:var(--c6);border-color:var(--c6);
}
.curator-id .linkedin-cta svg{width:15px;height:15px}
@media(max-width:700px){
  .curator-body{grid-template-columns:1fr;gap:20px}
  .curator-avatar{width:96px;height:96px}
  .curator-avatar .monogram{font-size:32px}
}

/* ================================================================
   Gate inner wrapper — stacks login card + pre-login blog note
   ================================================================ */
.gate-inner{
  display:flex;flex-direction:column;align-items:center;
  gap:16px;width:min(560px,100%);padding:16px 0;
}

/* ================================================================
   Pre-login blog note (gate)
   ================================================================ */
.gate-blog-note{
  width:100%;
  background:#ffffff;
  border:1px solid var(--hair);
  border-radius:var(--radius);
  padding:22px 26px 20px;
  animation:gateFade .5s ease .15s both;
}
.gate-blog-note:empty{display:none}
.gate-blog-note .gnb-top{margin-bottom:14px}
.gate-blog-note .gnb-logo{height:56px;width:auto;display:block}
.gate-blog-note h3{
  font-weight:500;font-size:14.5px;margin:0 0 7px;
  color:var(--ink);letter-spacing:-.005em;line-height:1.3;
}
.gate-blog-note p{
  font-size:13px;color:var(--ink-soft);line-height:1.65;margin:0 0 12px;
}
.gate-blog-note a.gnb-link{
  display:block;width:100%;text-align:center;
  margin-top:16px;
  background:var(--ink);color:#fff;
  border-radius:99px;text-decoration:none;
  padding:14px 22px;
  font-size:14.5px;letter-spacing:.02em;font-weight:400;
  box-shadow:0 10px 24px -14px rgba(21,21,28,.5);
  transition:background .25s, transform .2s, box-shadow .25s;
}
.gate-blog-note a.gnb-link:hover{
  background:var(--c6);transform:translateY(-1px);
}

/* ================================================================
   Post-login blog section
   ================================================================ */
.blog-posts{display:flex;flex-direction:column;gap:20px;max-width:780px}

.blog-card{
  border:1px solid var(--hair);border-radius:var(--radius);
  background:var(--paper-warm);overflow:hidden;
  border-top:3px solid var(--c6);
  transition:border-color .3s, box-shadow .3s;
}
.blog-card:hover{
  border-color:var(--c6);
  box-shadow:0 10px 32px -18px rgba(21,21,28,.18);
}
.blog-card-inner{padding:28px 32px 26px}
.blog-card .bc-meta{
  display:flex;align-items:center;gap:10px;
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink-mute);margin-bottom:12px;
}
.blog-card .bc-meta .bc-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--c6);display:inline-block;
}
.blog-card h3{
  font-weight:500;font-size:18px;margin:0 0 12px;
  color:var(--ink);letter-spacing:-.01em;line-height:1.3;
}
.blog-card .bc-body p{
  font-size:15px;color:var(--ink-soft);line-height:1.7;margin:0 0 .9em;
}
.blog-card .bc-body p:last-child{margin-bottom:0}
.blog-card .bc-footer{
  display:flex;align-items:center;justify-content:flex-end;
  margin-top:20px;padding-top:18px;border-top:1px solid var(--hair);
}
.blog-card a.bc-link{
  display:inline-flex;align-items:center;gap:7px;
  padding:8px 16px;border:1px solid var(--hair-strong);border-radius:99px;
  text-decoration:none;color:var(--ink);font-size:13px;letter-spacing:.02em;
  transition:background .25s, border-color .25s, color .25s;
}
.blog-card a.bc-link:hover{
  background:var(--c6);border-color:var(--c6);color:#fff;
}
@media(max-width:640px){
  .blog-card-inner{padding:22px 20px 18px}
  .blog-card h3{font-size:16px}
}
@media(max-width:520px){
  .gate-blog-note{padding:18px 18px 16px}
}
