/* ============================================================
   SkippyApp, publieke marketingsite (warme "Zonsondergang"-stijl).
   Hergebruikt de tokens + knoppen uit skippy.css. Aparte, bredere
   layout dan het app-portaal (full-width, secties, footer).
   ============================================================ */

.sks-body{ background:var(--sk-canvas); color:var(--sk-text); font-family:var(--sk-font); }
.sks-wrap{ max-width:1080px; margin:0 auto; padding:0 1.1rem; }
.sks-wrap-sm{ max-width:760px; margin:0 auto; padding:0 1.1rem; }
.sks-section{ padding:3.2rem 0; }
.sks-section.tight{ padding:2rem 0; }
h1,h2,h3{ letter-spacing:-.02em; }
.sks-eyebrow{ display:inline-flex; align-items:center; gap:.5rem; font-weight:800; font-size:.78rem; text-transform:uppercase; letter-spacing:.08em; color:var(--sk-primary-700); background:var(--sk-soft); padding:.35rem .8rem; border-radius:var(--sk-pill); }
.sks-lead{ font-size:1.15rem; color:var(--sk-muted); max-width:42rem; line-height:1.6; }
.sks-center{ text-align:center; }
.sks-center .sks-lead{ margin-left:auto; margin-right:auto; }

/* ── Topbar ─────────────────────────────────────────── */
.sks-top{ position:sticky; top:0; z-index:50; background:color-mix(in srgb,var(--sk-canvas) 88%,transparent); backdrop-filter:saturate(1.3) blur(12px); border-bottom:1px solid var(--sk-border); }
.sks-top-in{ max-width:1080px; margin:0 auto; padding:.6rem 1.1rem; display:flex; align-items:center; gap:1rem; }
.sks-brand{ display:flex; align-items:center; gap:.55rem; font-weight:800; font-size:1.15rem; color:var(--sk-text); text-decoration:none; }
.sks-logo{ width:38px; height:38px; border-radius:12px; background:var(--sk-sunset); display:grid; place-content:center; color:#fff; font-size:1.2rem; box-shadow:var(--sk-shadow-sm); }
.sks-nav{ display:flex; align-items:center; gap:.3rem; margin-left:auto; }
.sks-nav a{ padding:.5rem .8rem; border-radius:var(--sk-pill); color:var(--sk-text); font-weight:600; font-size:.92rem; text-decoration:none; }
.sks-nav a:hover{ background:var(--sk-soft); color:var(--sk-primary-700); }
.sks-nav .sks-login{ color:var(--sk-primary-700); font-weight:700; }
.sks-burger{ display:none; margin-left:auto; width:42px; height:42px; border:0; background:var(--sk-soft); border-radius:12px; color:var(--sk-text); font-size:1.1rem; cursor:pointer; }
@media(max-width:860px){
  .sks-nav{ position:fixed; inset:0 0 0 auto; width:min(80%,320px); flex-direction:column; align-items:stretch; gap:.2rem; background:var(--sk-canvas); padding:5rem 1rem 1rem; transform:translateX(100%); transition:.25s; box-shadow:var(--sk-shadow-lg); }
  .sks-nav.open{ transform:none; }
  .sks-nav a{ padding:.85rem 1rem; }
  .sks-burger{ display:grid; place-content:center; }
}

/* ── Hero ───────────────────────────────────────────── */
.sks-hero{ position:relative; overflow:hidden; }
.sks-hero-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:2.5rem; align-items:center; }
.sks-hero h1{ font-size:clamp(2rem,4.5vw,3.3rem); line-height:1.08; margin:.8rem 0 1rem; }
.sks-hero h1 .grad{ background:var(--sk-sunset); -webkit-background-clip:text; background-clip:text; color:transparent; }
.sks-hero-cta{ display:flex; flex-wrap:wrap; gap:.7rem; margin-top:1.6rem; }
.sks-trust{ display:flex; gap:1.2rem; margin-top:1.4rem; flex-wrap:wrap; color:var(--sk-muted); font-size:.86rem; font-weight:600; }
.sks-trust span{ display:inline-flex; align-items:center; gap:.4rem; }
.sks-trust i{ color:var(--sk-success); }
@media(max-width:860px){ .sks-hero-grid{ grid-template-columns:1fr; gap:1.5rem; } .sks-hero-art{ order:-1; } }

/* ── Phone mockup ───────────────────────────────────── */
.sks-phone{ width:280px; max-width:80vw; margin:0 auto; border:11px solid #1c1109; border-radius:38px; background:var(--sk-canvas); box-shadow:var(--sk-shadow-lg); overflow:hidden; }
.sks-phone-bar{ background:var(--sk-sunset); color:#fff; padding:.7rem .9rem; display:flex; align-items:center; gap:.5rem; font-weight:800; }
.sks-phone-bar .d{ margin-left:auto; display:flex; gap:.5rem; opacity:.9; }
.sks-phone-body{ padding:.8rem; display:flex; flex-direction:column; gap:.6rem; background:var(--sk-canvas); min-height:420px; }
.sks-mini-card{ background:var(--sk-card); border:1px solid var(--sk-border); border-radius:14px; padding:.7rem .8rem; box-shadow:var(--sk-shadow-sm); }
.sks-mini-hero{ background:var(--sk-sunset); color:#fff; border:0; }
.sks-mini-row{ display:flex; align-items:center; gap:.5rem; font-size:.8rem; }
.sks-mini-av{ width:26px; height:26px; border-radius:50%; background:var(--sk-glow); color:#fff; display:grid; place-content:center; font-weight:800; font-size:.72rem; flex:none; }
.sks-mini-chip{ margin-left:auto; background:var(--sk-soft); color:var(--sk-primary-700); border-radius:99px; padding:.1rem .5rem; font-weight:800; font-size:.7rem; }
.sks-mini-nav{ display:flex; justify-content:space-around; border-top:1px solid var(--sk-border); padding-top:.5rem; color:var(--sk-muted); font-size:1rem; margin-top:auto; }
.sks-mini-nav .on{ color:var(--sk-primary); }
.sks-float{ animation:sks-float 4s ease-in-out infinite; }
@keyframes sks-float{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-10px); } }

/* ── USP / feature grids ────────────────────────────── */
.sks-grid{ display:grid; gap:1.1rem; }
.sks-grid-3{ grid-template-columns:repeat(3,1fr); }
.sks-grid-2{ grid-template-columns:repeat(2,1fr); }
.sks-grid-4{ grid-template-columns:repeat(4,1fr); }
@media(max-width:860px){ .sks-grid-3,.sks-grid-4{ grid-template-columns:1fr 1fr; } }
@media(max-width:560px){ .sks-grid-3,.sks-grid-2,.sks-grid-4{ grid-template-columns:1fr; } }
.sks-usp{ background:var(--sk-card); border:1px solid var(--sk-border); border-radius:var(--sk-radius); padding:1.4rem; box-shadow:var(--sk-shadow-sm); transition:transform .15s, box-shadow .15s; }
.sks-usp:hover{ transform:translateY(-3px); box-shadow:var(--sk-shadow); }
.sks-usp .ic{ width:50px; height:50px; border-radius:14px; background:var(--sk-sunset-soft); color:var(--sk-primary); display:grid; place-content:center; font-size:1.4rem; margin-bottom:.9rem; }
.sks-usp h3{ font-size:1.1rem; margin:0 0 .4rem; }
.sks-usp p{ color:var(--sk-muted); margin:0; font-size:.94rem; line-height:1.55; }
.sks-usp a{ color:var(--sk-primary-700); font-weight:700; font-size:.9rem; text-decoration:none; display:inline-block; margin-top:.6rem; }

/* ── Split feature row ──────────────────────────────── */
.sks-split{ display:grid; grid-template-columns:1fr 1fr; gap:2.4rem; align-items:center; }
.sks-split.flip .sks-split-art{ order:2; }
@media(max-width:860px){ .sks-split{ grid-template-columns:1fr; gap:1.4rem; } .sks-split.flip .sks-split-art{ order:0; } }
.sks-split h2{ font-size:1.7rem; margin:0 0 .7rem; }
.sks-split p{ color:var(--sk-muted); line-height:1.65; }
.sks-checklist{ list-style:none; padding:0; margin:1rem 0 0; }
.sks-checklist li{ display:flex; gap:.6rem; align-items:flex-start; margin:.55rem 0; font-weight:500; }
.sks-checklist i{ color:var(--sk-success); margin-top:.2rem; }

/* ── Problem band ───────────────────────────────────── */
.sks-band{ background:var(--sk-soft); }
.sks-prob{ display:flex; gap:.7rem; align-items:flex-start; }
.sks-prob .x{ color:var(--sk-danger); font-size:1.1rem; margin-top:.15rem; }

/* ── Stats ──────────────────────────────────────────── */
.sks-stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; }
@media(max-width:560px){ .sks-stats{ grid-template-columns:1fr 1fr; } }
.sks-stat{ text-align:center; }
.sks-stat b{ display:block; font-size:2rem; font-weight:800; color:var(--sk-primary); }
.sks-stat span{ color:var(--sk-muted); font-size:.86rem; }

/* ── CTA band ───────────────────────────────────────── */
.sks-cta{ background:var(--sk-sunset); color:#fff; border-radius:var(--sk-radius-lg); padding:2.6rem 1.5rem; text-align:center; box-shadow:var(--sk-shadow); }
.sks-cta h2{ color:#fff; font-size:1.9rem; margin:0 0 .6rem; }
.sks-cta p{ opacity:.95; max-width:34rem; margin:0 auto 1.4rem; }
.sks-cta .sk-btn{ background:#fff; color:var(--sk-primary-700); }
.sks-cta .sk-btn-ghost{ background:rgba(255,255,255,.16); color:#fff; }

/* ── FAQ ────────────────────────────────────────────── */
.sks-faq details{ background:var(--sk-card); border:1px solid var(--sk-border); border-radius:var(--sk-radius); padding:.2rem 1.1rem; margin-bottom:.7rem; }
.sks-faq summary{ list-style:none; cursor:pointer; font-weight:700; padding:1rem 0; display:flex; justify-content:space-between; align-items:center; gap:1rem; }
.sks-faq summary::-webkit-details-marker{ display:none; }
.sks-faq summary::after{ content:"\f067"; font-family:"Font Awesome 6 Free"; font-weight:900; color:var(--sk-primary); font-size:.85rem; }
.sks-faq details[open] summary::after{ content:"\f068"; }
.sks-faq p{ color:var(--sk-muted); margin:0 0 1rem; line-height:1.65; }

/* ── Prose (article content) ────────────────────────── */
.sks-prose{ font-size:1.04rem; line-height:1.75; color:var(--sk-text); }
.sks-prose h2{ font-size:1.6rem; margin:2rem 0 .8rem; }
.sks-prose h3{ font-size:1.2rem; margin:1.4rem 0 .5rem; }
.sks-prose p{ margin:.7rem 0; color:#5b4636; }
[data-theme="dark"] .sks-prose p{ color:var(--sk-muted); }
.sks-prose ul{ padding-left:1.2rem; }
.sks-prose li{ margin:.4rem 0; }
.sks-breadcrumb{ font-size:.84rem; color:var(--sk-muted); margin:1.4rem 0 0; }
.sks-breadcrumb a{ color:var(--sk-primary-700); text-decoration:none; }

/* ── Install banner / steps ─────────────────────────── */
.sks-install{ background:var(--sk-card); border:1px solid var(--sk-border); border-radius:var(--sk-radius-lg); padding:1.6rem; box-shadow:var(--sk-shadow-sm); }
.sks-steps-num{ counter-reset:s; list-style:none; padding:0; margin:0; }
.sks-steps-num li{ counter-increment:s; display:flex; gap:.9rem; align-items:flex-start; margin:.9rem 0; }
.sks-steps-num li::before{ content:counter(s); flex:none; width:32px; height:32px; border-radius:50%; background:var(--sk-sunset); color:#fff; font-weight:800; display:grid; place-content:center; }

/* ── Footer ─────────────────────────────────────────── */
.sks-footer{ background:#2a1a12; color:#f4e7dd; padding:3rem 0 2rem; margin-top:2rem; }
[data-theme="dark"] .sks-footer{ background:#140d08; }
.sks-footer-grid{ display:grid; grid-template-columns:1.4fr repeat(4,1fr); gap:1.6rem; }
@media(max-width:860px){ .sks-footer-grid{ grid-template-columns:1fr 1fr; gap:1.4rem; } }
@media(max-width:480px){ .sks-footer-grid{ grid-template-columns:1fr; } }
.sks-footer h4{ font-size:.82rem; text-transform:uppercase; letter-spacing:.06em; color:#ffc7b0; margin:0 0 .8rem; font-weight:800; }
.sks-footer a{ display:block; color:#fff; text-decoration:none; padding:.32rem 0; font-size:.94rem; opacity:.88; }
.sks-footer a:hover{ color:#fff; opacity:1; text-decoration:underline; }
.sks-footer-brand p{ color:#f3e4da; font-size:.92rem; line-height:1.6; max-width:22rem; }
.sks-footer-bottom{ border-top:1px solid rgba(255,255,255,.12); margin-top:2rem; padding-top:1.3rem; display:flex; justify-content:space-between; flex-wrap:wrap; gap:.6rem; color:#c9b3a6; font-size:.85rem; }

/* Knoppen in header/footer mogen NIET door de link-stijl (display:block,
   kleur, padding) gesloopt worden. Forceer echte knop-opmaak + witte tekst. */
.sks-top .sk-btn, .sks-footer .sk-btn{ display:inline-flex; align-items:center; gap:.5rem; width:auto; color:#fff; opacity:1; padding:.55rem 1rem; border-radius:var(--sk-pill); box-shadow:var(--sk-shadow-sm); }
.sks-top .sk-btn:hover, .sks-footer .sk-btn:hover{ color:#fff; }
.sks-top .sk-btn i, .sks-footer .sk-btn i{ color:#fff; }

/* Mobiel off-canvas-menu: scrim erachter zodat het sluit bij tikken ernaast. */
.sks-nav-scrim{ position:fixed; inset:0; background:rgba(40,26,18,.5); z-index:45; opacity:0; pointer-events:none; transition:opacity .25s; }
.sks-nav-scrim.open{ opacity:1; pointer-events:auto; }
@media(min-width:861px){ .sks-nav-scrim{ display:none!important; } }
@media(max-width:860px){ .sks-nav{ z-index:55; } }

/* ── Showcase-slider: complete mockups + info, een per keer ─── */
.sks-slider{ position:relative; overflow:hidden; }
.sks-slides{ display:flex; transition:transform .5s cubic-bezier(.22,1,.36,1); will-change:transform; }
.sks-slide{ min-width:100%; padding:.3rem; }
.sks-slide-grid{ display:grid; grid-template-columns:1fr 1fr; gap:2.6rem; align-items:center; }
@media(max-width:860px){ .sks-slide-grid{ grid-template-columns:1fr; gap:1.4rem; } .sks-slide-art{ order:-1; } }
.sks-slide .sks-eyebrow{ margin-bottom:.6rem; }
.sks-slide h3{ font-size:clamp(1.4rem,3vw,2rem); margin:.3rem 0 .7rem; }
.sks-slide p{ color:var(--sk-muted); line-height:1.65; font-size:1.05rem; margin:0; }
.sks-slider-ctrl{ display:flex; align-items:center; justify-content:center; gap:1.1rem; margin-top:1.7rem; }
.sks-slider-ctrl .nav{ width:46px; height:46px; border-radius:50%; border:1px solid var(--sk-border-2); background:var(--sk-card); color:var(--sk-text); cursor:pointer; font-size:1rem; box-shadow:var(--sk-shadow-sm); display:grid; place-content:center; }
.sks-slider-ctrl .nav:hover{ background:var(--sk-soft); color:var(--sk-primary-700); }
.sks-slider-dots{ display:flex; gap:8px; }
.sks-slider-dots i{ width:9px; height:9px; border-radius:99px; background:var(--sk-border-2); cursor:pointer; transition:.3s; }
.sks-slider-dots i.on{ width:28px; background:var(--sk-primary); }

/* ── Animerende demo-telefoon (bediening door de tabs) ─── */
.sks-demo{ width:300px; max-width:84vw; margin:0 auto; }
.sks-demo-phone{ border:12px solid #1c1109; border-radius:42px; background:var(--sk-canvas); box-shadow:var(--sk-shadow-lg); overflow:hidden; }
.sks-demo-bar{ background:var(--sk-sunset); color:#fff; padding:.7rem .9rem; display:flex; align-items:center; gap:.5rem; font-weight:800; font-size:.9rem; }
.sks-demo-bar .d{ margin-left:auto; display:flex; gap:.55rem; opacity:.9; font-size:.85rem; }
.sks-demo-screens{ position:relative; height:436px; background:var(--sk-canvas); }
.sks-screen{ position:absolute; inset:0; padding:.8rem; display:flex; flex-direction:column; gap:.55rem; opacity:0; transform:translateY(10px); transition:opacity .45s ease, transform .45s ease; pointer-events:none; }
.sks-screen.on{ opacity:1; transform:none; }
.sks-demo-nav{ display:flex; justify-content:space-around; border-top:1px solid var(--sk-border); padding:.5rem 0 .55rem; background:var(--sk-card); }
.sks-demo-nav .ni{ border:0; background:none; color:var(--sk-faint); display:flex; flex-direction:column; align-items:center; gap:3px; font-size:1.1rem; transition:color .3s; }
.sks-demo-nav .ni .lab{ font-size:.56rem; font-weight:800; }
.sks-demo-nav .ni.on{ color:var(--sk-primary); }
.sks-demo-cap{ text-align:center; margin-top:1rem; font-weight:800; color:var(--sk-primary-700); min-height:1.5em; }
.sks-demo-dots{ display:flex; gap:6px; justify-content:center; margin-top:.5rem; }
.sks-demo-dots i{ width:7px; height:7px; border-radius:99px; background:var(--sk-border-2); transition:.3s; }
.sks-demo-dots i.on{ width:20px; background:var(--sk-primary); }

/* ── Concrete capability-lijst (geen losse kaartjes) ──── */
.sks-caps{ max-width:680px; margin:0 auto; display:grid; gap:.5rem; }
.sks-cap{ display:flex; gap:1rem; align-items:flex-start; background:var(--sk-card); border:1px solid var(--sk-border); border-radius:var(--sk-radius); padding:1rem 1.1rem; box-shadow:var(--sk-shadow-sm); }
.sks-cap .ic{ width:46px; height:46px; border-radius:13px; background:var(--sk-sunset-soft); color:var(--sk-primary); display:grid; place-content:center; font-size:1.25rem; flex:none; }
.sks-cap b{ display:block; font-size:1.02rem; }
.sks-cap span{ color:var(--sk-muted); font-size:.94rem; line-height:1.5; }

/* App-installatie: iOS hulp-sheet */
.sks-ios{ position:fixed; inset:auto 0 0 0; z-index:90; background:var(--sk-card); border-top:1px solid var(--sk-border); box-shadow:var(--sk-shadow-lg); padding:1.2rem 1.1rem calc(1.2rem + env(safe-area-inset-bottom)); transform:translateY(110%); transition:.3s; }
.sks-ios.open{ transform:none; }
.sks-ios .x{ position:absolute; top:.8rem; right:1rem; border:0; background:none; font-size:1.2rem; color:var(--sk-muted); cursor:pointer; }
