/* Homepage CannonWorks — revamped page styles */

:root{
  --blue:#0093df;
  --blue-dark:#007ec0;
  --blue-soft:#e6f4fc;
  --ink:#1c2b39;
  --muted:#5b6b7a;
  --line:#dde8f0;
  --sky:#f4f9fd;
  --radius:18px;
  --shadow:0 14px 34px rgba(0,86,130,.12);
  --display:'Baloo 2',sans-serif;
  --section-py:72px;
  --text-max:52ch;
}

html{scroll-behavior:smooth}
section[id]{scroll-margin-top:90px}

.page-content{
  font-family:'Lato',sans-serif;
  font-size:17px;
  line-height:1.65;
  color:var(--ink);
}
.page-content img{max-width:100%;height:auto;display:block}
.page-content figure{margin:0}
.page-content a{color:var(--blue-dark)}

.wrap{max-width:1140px;margin:0 auto;padding:0 24px}

/* ---- Typography ---- */
.page-content h1,
.page-content h2,
.page-content h3{
  font-family:var(--display);
  font-weight:800;
  text-transform:uppercase;
  line-height:1.08;
  letter-spacing:.01em;
  color:var(--ink);
  margin:0 0 18px;
}
.page-content h1{font-size:clamp(2.4rem,5.2vw,3.9rem)}
.page-content h2{font-size:clamp(1.7rem,3.4vw,2.5rem);max-width:62ch}
.page-content h3{font-size:1.2rem;margin:26px 0 8px}
.page-content h1 em,
.page-content h2 em{font-style:normal;color:var(--blue)}

.kicker{
  font-weight:900;font-size:.82rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--blue);margin:0 0 14px;
}
.kicker--light{color:#bfe4f8;display:flex;align-items:center;gap:10px}
.appband__mark{width:28px;height:28px;object-fit:contain;border-radius:6px}

.page-content p{margin:0 0 16px;max-width:var(--text-max);color:var(--muted)}
.lead{font-size:1.1rem;color:var(--ink);max-width:var(--text-max)}
.lead--light{color:#dff0fa}
.soundbite{max-width:var(--text-max);color:var(--muted)}
.soundbite strong{color:var(--ink)}

.section-header--left{text-align:left;margin-bottom:40px}
.section-header--center{text-align:center}
.section-header--center h2,
.section-header--center .lead,
.section-header--center p{margin-left:auto;margin-right:auto}

/* ---- Buttons ---- */
.page-content .btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-weight:900;padding:16px 32px;border-radius:999px;font-size:1.02rem;
  letter-spacing:.02em;text-decoration:none;min-height:44px;
  transition:transform .15s,box-shadow .15s,background .15s;
}
.page-content .btn:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.page-content .btn-primary{background:var(--blue);color:#fff}
.page-content .btn-primary:hover{background:var(--blue-dark);color:#fff}
.page-content .btn-white{
  background:#fff;color:var(--blue);border:1px solid var(--line);
  box-shadow:0 2px 12px rgba(0,86,130,.08);
}
.page-content .btn-white:hover{background:#fff;color:var(--blue-dark);border-color:#c5d8e6}
.page-content .btn-soft{background:var(--blue-soft);color:var(--blue-dark)}

/* ---- Hero ---- */
.hero{
  background:linear-gradient(180deg,#fff 0%,var(--sky) 100%);
  padding:64px 0 56px;
}
.hero__grid{
  display:grid;grid-template-columns:1.08fr .92fr;
  gap:48px;align-items:center;
}
.hero__art{position:relative;justify-self:center}
.hero__art::before{
  content:'';position:absolute;inset:-6% -8%;z-index:0;
  background:var(--blue-soft);
  border-radius:48% 52% 46% 54%/58% 48% 52% 42%;
}
.hero__art img{
  position:relative;z-index:1;max-width:420px;width:100%;
  filter:drop-shadow(0 16px 28px rgba(0,86,130,.18));
}

.hero-search{
  display:flex;align-items:center;gap:8px;margin:18px 0 0;
  background:#fff;border:1px solid var(--line);border-radius:999px;
  padding:6px 6px 6px 18px;max-width:380px;
  box-shadow:0 2px 12px rgba(0,86,130,.08);
}
.hero-search__input{
  border:0;background:transparent;font:inherit;font-weight:700;
  width:100%;min-width:0;padding:10px 4px;color:var(--ink);
}
.hero-search__input--nr{max-width:90px}
.hero-search__btn{
  flex:0 0 44px;width:44px;height:44px;border:0;border-radius:50%;
  background:var(--blue);cursor:pointer;display:grid;place-items:center;
  transition:background .15s;
}
.hero-search__btn:hover{background:var(--blue-dark)}

/* ---- Proofbar ---- */
.proofbar{
  background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:22px 0;
}
.proofbar__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.proof{display:flex;align-items:baseline;gap:12px;text-align:left}
.proof__big{
  font-family:var(--display);font-weight:800;font-size:1.35rem;
  color:var(--blue);line-height:1;flex:0 0 auto;
}
.proof__txt{font-weight:700;font-size:.92rem;color:var(--ink)}

/* ---- Split sections ---- */
.split{padding:var(--section-py) 0;background:#fff}
.split--sky{background:var(--sky)}
.split__grid{
  display:grid;grid-template-columns:1.08fr .92fr;
  gap:60px;align-items:center;
}
.split__grid--flip{direction:rtl}
.split__grid--flip>*{direction:ltr}
.split__art{position:relative;justify-self:center}
.split__art::before{
  content:'';position:absolute;inset:-5% -9%;z-index:0;
  background:var(--blue-soft);
  border-radius:54% 46% 52% 48%/44% 56% 46% 54%;
}
.split--sky .split__art::before{background:#fff}
.split__art img{
  position:relative;z-index:1;max-width:400px;width:100%;
  filter:drop-shadow(0 16px 28px rgba(0,86,130,.18));
}
.split__art--photo::before{content:none}
.split__art--photo img{
  filter:none;border-radius:var(--radius);box-shadow:var(--shadow);max-width:480px;
}
.split__actions{margin-top:26px}

/* Boekje-sectie: twee subkolommen in de tekstzijde */
.boekje__cols{
  display:grid;grid-template-columns:1fr 1fr;gap:28px;margin-top:8px;
}
.boekje__cols h3{margin-top:0}

/* ---- Plan (stappen) ---- */
.plan{background:var(--sky);padding:var(--section-py) 0}
.plan__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:30px}
.plan-card{
  position:relative;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);padding:44px 26px 26px;text-align:center;
  text-decoration:none;color:var(--ink);
  transition:transform .15s,box-shadow .15s;
}
.plan-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.plan-card__badge{
  position:absolute;top:-22px;left:50%;transform:translateX(-50%);
  width:44px;height:44px;border-radius:50%;background:var(--blue);
  border:4px solid #fff;color:#fff;font-family:var(--display);font-weight:800;
  font-size:1.2rem;display:grid;place-items:center;
}
.plan-card img{height:165px;width:auto;object-fit:contain;margin:0 auto 16px}
.plan-card h3{color:var(--blue);margin:0 0 10px;font-size:1.15rem}
.plan-card p{margin:0 auto;font-size:.98rem}
.plan__cta{text-align:center;margin:44px 0 0}

/* ---- Checklist ---- */
.checks{list-style:none;padding:0;margin:0 0 20px;display:grid;gap:12px}
.checks--two{grid-template-columns:1fr 1fr;column-gap:28px}
.checks li{
  display:flex;align-items:flex-start;gap:12px;
  font-weight:700;color:var(--ink);
}
.check__dot{
  flex:0 0 23px;width:23px;height:23px;border-radius:50%;
  background:var(--blue);display:grid;place-items:center;margin-top:2px;
}
.check__dot svg{width:13px;height:13px}

/* ---- App-band (donker) ---- */
.appband{background:var(--ink);padding:var(--section-py) 0;color:#dff0fa}
.appband h2{color:#fff}
.appband p{color:#bfd2df}
.appband .checks li{color:#fff}
.appband__grid{
  display:grid;grid-template-columns:.9fr 1.1fr;gap:60px;align-items:center;
}
.appband__art{justify-self:center;position:relative}
.appband__art::before{
  content:'';position:absolute;inset:-6% -10%;z-index:0;
  background:rgba(0,147,223,.18);
  border-radius:46% 54% 50% 50%/56% 44% 54% 46%;
}
.appband__art img{
  position:relative;z-index:1;max-width:380px;width:100%;
  filter:drop-shadow(0 16px 28px rgba(0,0,0,.35));
}
.appband__note{font-size:.98rem}
.appband__badges{display:flex;gap:14px;margin-top:22px;flex-wrap:wrap}
.appband__badges img{height:48px;width:auto}

/* ---- Slot-CTA ---- */
.slot{background:#fff;padding:72px 0 48px;text-align:center}
.slot__title{max-width:24ch}
.slot__lead{max-width:52ch}
.slot__actions{
  display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin:28px 0 0;
}
.triptych{
  display:flex;align-items:flex-end;justify-content:center;
  gap:32px;margin-top:48px;
}
.triptych__side{flex:0 0 24%;max-width:24%}
.triptych__center{flex:0 0 42%;max-width:480px}
.triptych img{width:100%;height:auto}

/* ---- Reveal / motion / focus ---- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
  .header-nav a::after{transition:none}
  .page-content .btn,
  .plan-card{transition:none}
}

.page-content :focus-visible{outline:3px solid var(--blue);outline-offset:2px;border-radius:6px}

/* ---- Responsive ---- */
@media(max-width:1024px){
  .proofbar__grid{grid-template-columns:repeat(2,1fr)}
}

@media(max-width:920px){
  :root{--section-py:56px}
  .hero{padding:56px 0 48px}
  .hero__grid{grid-template-columns:1fr;gap:0}
  .hero__art{display:none}
  .split__grid,
  .split__grid--flip,
  .appband__grid{grid-template-columns:1fr;gap:32px;direction:ltr}
  .split__art{order:-1}
  .split__art img{max-width:320px}
  .split__art--photo img{max-width:100%}
  .plan__grid{grid-template-columns:1fr;gap:40px}
  .boekje__cols{grid-template-columns:1fr}
  .checks--two{grid-template-columns:1fr}
  .appband__art img{max-width:300px}
}

@media(max-width:560px){
  .proofbar__grid{grid-template-columns:1fr;gap:14px}
  .page-content .btn{width:100%}
  .hero-search{max-width:100%}
  .slot__actions{flex-direction:column;align-items:stretch}
  .triptych__side,
  .hide-mobile{display:none !important}
  .triptych{gap:0;margin-top:36px}
  .triptych__center{flex:1 1 100%;max-width:100%;margin:0 auto}
}

@media(max-width:390px){
  .wrap{padding:0 18px}
  .hero{padding:48px 0 40px}
  .plan-card img{height:130px}
  .triptych__center{max-width:88%}
}