/* Mobile + tablet polish — gedeeld over alle 4 pages.
   Wordt na de page-inline <style> geladen, dus normale cascade volstaat. */

/* ── Globaal: nooit horizontaal overflow ── */
html,body{overflow-x:hidden;max-width:100vw}
img,svg,iframe{max-width:100%}
.delivery-scene,.top-marquee,.mid-marquee,.bot-marquee{overflow-x:hidden}

/* iOS notch / safe-area: sticky nav respects safe-area-inset */
nav{top:max(24px, env(safe-area-inset-top, 24px))}

/* Touch-targets minimaal 44x44 op alle interactieve elementen (WCAG 2.5.5) */
@media (hover: none) and (pointer: coarse){
  .chip,.btn,.btn-pri,.btn-sec,.btn-submit,.nav-cta,.nav-links a,.card .go,.florist-item,.foot-top a,.add{min-height:44px}
  .chip{padding:12px 18px}
  .filt-lab + .chip{margin-left:0}
}

/* Leaflet attribution klein op mobile */
@media (max-width:480px){
  .leaflet-control-attribution{font-size:9px;padding:2px 6px}
}

/* :invalid form-styling — kleur de input rood-perzik wanneer ongeldig */
.form input:user-invalid,.form select:user-invalid,.form textarea:user-invalid{border-color:#e08858;background:rgba(224,136,88,.06)}
.form-success.error{border-color:#e08858;background:rgba(224,136,88,.06);color:#6e3a17}

/* ── Hamburger + mobile menu (default: hidden op desktop, getoond ≤820px) ── */
.nav-burger{display:none}
.mobile-menu{display:none}

/* ═══════════════════════════════════════════════════════════════
   TABLET (≤ 1100px)
   ═══════════════════════════════════════════════════════════════ */
@media (max-width:1100px){
  .wrap{padding:0 36px}

  /* Hero */
  .hero{padding:64px 0 96px}
  .hero h1{font-size:88px;line-height:.94}
  .hero-art{height:440px}
  .hero-art .ill svg{width:300px}

  /* Section heads stack al op tablet */
  .section-head{grid-template-columns:1fr;gap:20px;margin-bottom:40px}
  .section-head h2{font-size:60px}
  .section-head p.sub{font-size:16px;max-width:none}

  /* Hub cards: 6 = 3+3, 4 = ok */
  .card-rouw{grid-column:span 12;padding:40px}
  .card-2{grid-column:span 12}
  .card-3,.card-4{grid-column:span 6}

  /* Webshop */
  .pgrid{grid-template-columns:repeat(2,1fr)}
  .shead h1{font-size:84px}
  .anchor-inner{gap:48px}
  .anchor-band h2{font-size:60px}

  /* Florists */
  .map-layout{grid-template-columns:1fr}
  .florist-scroll{max-height:none}
  .map-frame{min-height:380px;height:380px}
  .florist-head h2{font-size:52px}
  .fleurop-inner{grid-template-columns:1fr;gap:32px}
  .fleurop-text h3{font-size:38px}

  /* Trust */
  .trust-inner{grid-template-columns:repeat(2,1fr)}
  .trust-cell{min-height:160px;padding:28px}
  .trust-cell .n{font-size:64px}

  /* Marquees iets kleiner */
  .mid-marquee .track{font-size:60px;gap:48px}
  .mid-marquee .track .flower{width:42px;height:42px}
  .bot-marquee .track{font-size:36px;gap:42px}

  /* Delivery scene */
  .delivery-scene .sky-text{font-size:52px}

  /* Contact */
  .contact-grid{grid-template-columns:1fr}
  .info-stack{position:static}
  .benefits-grid{grid-template-columns:repeat(2,1fr)}
  .cta-inner{grid-template-columns:1fr;gap:28px}
}

/* ═══════════════════════════════════════════════════════════════
   LARGE MOBILE / SMALL TABLET (≤ 820px)
   ═══════════════════════════════════════════════════════════════ */
@media (max-width:820px){
  .wrap{padding:0 22px}

  /* Nav compact, hide desktop links, toon hamburger */
  nav{margin-top:12px;top:max(12px, env(safe-area-inset-top, 12px))}
  .nav-inner{display:flex;align-items:center;height:68px;padding:0 12px 0 18px;gap:8px;grid-template-columns:none}
  .logo{margin-right:auto}
  .logo img{height:48px}
  .nav-links{display:none}
  .nav-cta{padding:10px 16px;font-size:13px}

  /* Hamburger button — 2 lijntjes asymmetric (kort boven, lang onder), draait naar X bij open */
  .nav-burger{position:relative;display:inline-flex;flex-direction:column;align-items:flex-end;justify-content:center;width:46px;height:46px;background:transparent;border:1px solid rgba(31,77,44,.18);cursor:pointer;border-radius:999px;flex:none;padding:0 11px;gap:6px;transition:background .25s,border-color .25s}
  .nav-burger:hover,.nav-burger:focus-visible{background:rgba(31,77,44,.06);border-color:rgba(31,77,44,.35);outline:none}
  .nav-burger span{display:block;height:2px;background:var(--moss-deep);border-radius:2px;transition:width .3s cubic-bezier(.22,1,.36,1),transform .3s cubic-bezier(.22,1,.36,1),opacity .25s}
  .nav-burger span:nth-child(1){width:12px}
  .nav-burger span:nth-child(2){width:20px}
  .nav-burger:hover span:nth-child(1),.nav-burger:focus-visible span:nth-child(1){width:20px}
  .nav-burger[aria-expanded="true"]{background:var(--moss);border-color:var(--moss)}
  .nav-burger[aria-expanded="true"] span{background:var(--cream);width:20px;position:absolute;top:50%;left:50%;margin:0}
  .nav-burger[aria-expanded="true"] span:nth-child(1){transform:translate(-50%,-50%) rotate(45deg)}
  .nav-burger[aria-expanded="true"] span:nth-child(2){transform:translate(-50%,-50%) rotate(-45deg)}

  /* Mobile fullscreen menu */
  .mobile-menu{display:block;position:fixed;inset:0;background:rgba(243,237,220,.985);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);z-index:49;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease;overflow-y:auto;padding-top:max(96px,calc(env(safe-area-inset-top,0px) + 96px));padding-bottom:max(24px,env(safe-area-inset-bottom,24px))}
  .mobile-menu.open{opacity:1;visibility:visible}
  .mobile-menu-inner{display:flex;flex-direction:column;padding:0 28px;max-width:560px;margin:0 auto}
  .mobile-menu-inner a{font-family:'Sora',sans-serif;font-size:30px;font-weight:500;letter-spacing:-.015em;color:var(--moss-deep);padding:20px 4px;border-bottom:1px solid rgba(31,77,44,.12);display:flex;align-items:center;justify-content:space-between;gap:16px;transform:translateY(12px);opacity:0;transition:transform .35s cubic-bezier(.22,1,.36,1),opacity .35s ease,color .2s}
  .mobile-menu.open .mobile-menu-inner a{transform:translateY(0);opacity:1}
  .mobile-menu.open .mobile-menu-inner a:nth-child(1){transition-delay:.05s}
  .mobile-menu.open .mobile-menu-inner a:nth-child(2){transition-delay:.10s}
  .mobile-menu.open .mobile-menu-inner a:nth-child(3){transition-delay:.15s}
  .mobile-menu.open .mobile-menu-inner a:nth-child(4){transition-delay:.20s}
  .mobile-menu.open .mobile-menu-inner a:nth-child(5){transition-delay:.25s}
  .mobile-menu.open .mobile-menu-inner a:nth-child(6){transition-delay:.30s}
  .mobile-menu-inner a:active,.mobile-menu-inner a:hover{color:var(--moss)}
  .mobile-menu-inner a.active{color:var(--moss)}
  .mobile-menu-inner a.active::before{content:"";display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--peach-2);margin-right:4px;flex:none}
  .mobile-menu-inner a::after{content:"→";font-family:'DM Serif Display',serif;font-style:italic;color:var(--peach-2);opacity:.65;font-size:26px;transition:transform .25s,opacity .25s}
  .mobile-menu-inner a:active::after{transform:translateX(8px);opacity:1}
  .mobile-menu-cta{margin-top:28px;display:inline-flex;align-items:center;justify-content:center;gap:10px;background:var(--moss);color:var(--cream)!important;padding:18px 28px;border-radius:999px;font-family:'Sora',sans-serif;font-size:16px;font-weight:500;border-bottom:none!important;transform:translateY(12px);opacity:0;transition:transform .35s cubic-bezier(.22,1,.36,1) .35s,opacity .35s ease .35s,background .2s}
  .mobile-menu.open .mobile-menu-cta{transform:translateY(0);opacity:1}
  .mobile-menu-cta::after{display:none!important}
  .mobile-menu-cta:active,.mobile-menu-cta:hover{background:var(--moss-deep)!important;color:var(--cream)!important}
  body.menu-open{overflow:hidden}

  @media (prefers-reduced-motion:reduce){
    .mobile-menu,.mobile-menu .mobile-menu-inner a,.mobile-menu-cta,.nav-burger span{transition:none}
  }

  /* Hero: stack, kleiner */
  .hero{padding:40px 0 64px}
  .hero-grid{grid-template-columns:1fr;gap:24px}
  .hero h1{font-size:64px;line-height:.96}
  .hero h1 .b{font-size:.88em}
  .hero p.lede{font-size:16.5px;max-width:none}
  .pill{font-size:12px;padding:8px 14px;margin-bottom:18px}
  .hero-actions{margin-top:24px;gap:10px}
  .btn{padding:14px 22px;font-size:14px}
  .hero-art{height:280px;margin-top:8px}
  .hero-art .ill svg{width:220px}
  .blob.b1{width:200px;height:220px;left:20px;top:20px}
  .blob.b2{width:120px;height:120px;top:60px;right:10px}
  .blob.b3{width:96px;height:96px;bottom:30px;left:60px}
  .hero-art .tag{bottom:8px;right:0;padding:10px 14px;font-size:12px}

  /* Top marquee kleiner */
  .top-marquee{font-size:11.5px;padding:8px 0}

  /* Delivery scene */
  .delivery-scene{padding:48px 0 0}
  .delivery-scene .sky-text{font-size:34px;padding:0 18px;line-height:1.04}
  .delivery-scene .sub-text{font-size:11px}
  .delivery-scene .road{height:200px;margin-top:20px}
  .delivery-scene .truck{height:170px}
  .delivery-scene .ground{height:60px}

  /* Section heads kleiner */
  .section-head{margin-bottom:30px;gap:14px}
  .section-head h2{font-size:42px;line-height:1.02;letter-spacing:-.028em}
  .section-head p.sub{font-size:15.5px}

  /* Hub cards */
  .cards{grid-template-columns:1fr;gap:14px}
  .card,.card-2,.card-3,.card-4{grid-column:span 1;padding:28px;border-radius:28px;min-height:auto}
  .card svg.ico{width:48px;height:48px;margin-bottom:18px}
  .card h3{font-size:24px}
  .card-rouw{grid-column:span 1;grid-template-columns:1fr;gap:24px;padding:32px;border-radius:32px}
  .card-rouw h3{font-size:34px;max-width:none}
  .card-rouw p{font-size:15.5px;max-width:none}
  .card-rouw .visual{height:180px;order:-1}
  .card-rouw .visual .b1{width:200px;height:200px;right:auto;left:50%;transform:translateX(-50%)}
  .card-rouw .visual .b2{width:120px;height:120px;right:auto;left:calc(50% - 80px);top:60px}
  .card-rouw .visual .b3{width:90px;height:90px;right:auto;left:calc(50% + 50px);top:30px}
  .card-rouw .visual svg{width:140px;right:auto;left:50%;transform:translate(-50%,-50%)}
  .card-rouw .badge{top:18px;right:18px;font-size:10px;padding:6px 10px}

  /* Trust 2×2, kleiner */
  .trust{padding:60px 0}
  .trust-inner{grid-template-columns:repeat(2,1fr);gap:12px}
  .trust-cell{min-height:130px;padding:22px;border-radius:24px}
  .trust-cell .n{font-size:44px}
  .trust-cell .l{font-size:11.5px}

  /* Why */
  .why{padding:60px 0}
  .why-grid{grid-template-columns:1fr;gap:14px;margin-top:30px}
  .why-item{min-height:auto;padding:26px;border-radius:24px}
  .why-item .ico-wrap{width:52px;height:52px}
  .why-item .ico-wrap svg{width:26px;height:26px}
  .why-item h4{font-size:20px}
  .why-item p{font-size:14px}

  /* Mid + bot marquees */
  .mid-marquee{padding:18px 0}
  .mid-marquee .track{font-size:38px;gap:28px}
  .mid-marquee .track span{gap:28px}
  .mid-marquee .track .flower{width:32px;height:32px}
  .bot-marquee{padding:16px 0}
  .bot-marquee .track{font-size:24px;gap:28px}
  .bot-marquee .track span{gap:28px}

  /* Fleurop band */
  .fleurop-band{padding:56px 0}
  .fleurop-logo-card{padding:22px 32px;align-self:flex-start}
  .fleurop-logo-card img{height:60px}
  .fleurop-text h3{font-size:28px;margin:10px 0 12px;max-width:none}
  .fleurop-text p{font-size:15.5px;max-width:none}
  .fleurop-stats{gap:22px;margin-top:18px}
  .fleurop-stats .s .n{font-size:26px}

  /* Florists */
  .florists{padding:56px 0}
  .florist-head h2{font-size:36px}
  .florist-head p{font-size:15.5px}
  .map-layout{padding:10px;border-radius:24px}
  .map-frame{min-height:300px;height:300px;border-radius:18px}
  .florist-scroll{max-height:none;padding:6px 4px}
  .florist-item{padding:12px;border-radius:16px;grid-template-columns:72px 1fr;gap:12px}
  .florist-photo{width:72px;height:72px}
  .florist-cta{margin-top:24px;padding:22px;flex-direction:column;align-items:flex-start;gap:14px;text-align:left;border-radius:20px}
  .florist-cta p{font-size:16px;max-width:none}
  .florist-cta a{padding:14px 22px;font-size:14px}

  /* Webshop shead */
  .shead{padding:48px 0 28px}
  .shead h1{font-size:54px;line-height:.98;margin:10px 0 14px}
  .shead p.lead{font-size:16px}
  .promise{gap:8px;margin-top:14px}
  .promise span{padding:8px 14px;font-size:13px}

  /* Webshop filters */
  .filters-row{padding:4px 0 18px}
  .filters{flex-wrap:wrap;gap:8px}
  .filt-lab{display:none}
  .chip{font-size:13px;padding:10px 16px}
  .sort{margin-left:0;width:100%;justify-content:flex-end;margin-top:6px}

  /* Webshop products */
  .products{padding:18px 0 56px}
  .pgrid{grid-template-columns:1fr;gap:18px}
  .prod{border-radius:24px}
  .prod-img{aspect-ratio:5/4}
  .prod-img svg.bouquet{width:52%}
  .prod-body{padding:20px 22px 22px}
  .prod-body h3{font-size:22px}
  .price{font-size:20px}
  .add{padding:11px 18px;font-size:13px}

  /* Webshop anchor bands */
  .anchor-band{padding:56px 0}
  .anchor-inner{grid-template-columns:1fr;gap:28px}
  .anchor-band h2{font-size:38px;max-width:none}
  .anchor-band p.lead{font-size:16.5px;margin-top:14px;max-width:none}
  .anchor-band ul.checks{margin-top:18px;gap:10px}
  .anchor-band ul.checks li{font-size:14.5px;max-width:none}
  .anchor-band .actions{margin-top:24px;gap:10px}
  .anchor-band .actions .btn{padding:13px 22px;font-size:14px}
  .anchor-visual{aspect-ratio:5/4;border-radius:28px}
  .anchor-visual svg{width:54%}

  /* Contact page hero */
  .page-hero{padding:40px 0 24px}
  .page-hero h1{font-size:48px;line-height:.98}
  .page-hero p.lede{font-size:16px}

  /* Contact form */
  .form-card{padding:28px 22px;border-radius:24px}
  .form{grid-template-columns:1fr;gap:14px}
  .field.full,.field{grid-column:span 1}
  .form-actions{grid-column:span 1;flex-direction:column;align-items:stretch;gap:12px}
  .form-actions .btn-submit{width:100%;justify-content:center}
  .info-card{padding:22px;border-radius:22px}
  .info-stack{position:static;gap:14px}

  /* Benefits */
  .benefits{padding:56px 0}
  .benefits-head h2{font-size:34px}
  .benefits-head p{font-size:15.5px}
  .benefits-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .benefit{padding:22px;border-radius:20px;min-height:auto;gap:10px}
  .benefit .ico-wrap{width:46px;height:46px}
  .benefit .ico-wrap svg{width:22px;height:22px}
  .benefit h4{font-size:16.5px}
  .benefit p{font-size:13.5px}

  /* CTA band */
  .cta-band{padding:56px 0}
  .cta-inner{grid-template-columns:1fr;gap:22px}
  .cta-inner h2{font-size:32px;max-width:none}
  .cta-inner p{font-size:15.5px;max-width:none}
  .cta-buttons{flex-direction:row;flex-wrap:wrap;gap:10px}
  .cta-buttons a{padding:14px 22px;font-size:14px}

  /* Footer */
  footer{padding:56px 0 28px}
  .foot-top{grid-template-columns:1fr 1fr;gap:28px;padding-bottom:32px}
  .foot-top .logo img{height:64px}
  .foot-top h5{font-size:11px;margin-bottom:10px}
  .foot-top a{font-size:13.5px}
  .foot-bot{flex-direction:column;gap:8px;font-size:12.5px;padding-top:20px;text-align:center;align-items:center}
}

/* ═══════════════════════════════════════════════════════════════
   MOBILE (≤ 640px)
   ═══════════════════════════════════════════════════════════════ */
@media (max-width:640px){
  .wrap{padding:0 18px}

  .hero h1{font-size:54px}
  .section-head h2{font-size:36px}

  /* Hub: maak alle vier kaarten 1 kolom */
  .card-3,.card-4{grid-column:span 1}

  .delivery-scene .sky-text{font-size:28px}
  .mid-marquee .track{font-size:32px;gap:24px}
  .mid-marquee .track span{gap:24px}
  .mid-marquee .track .flower{width:28px;height:28px}
  .bot-marquee .track{font-size:20px}

  .shead h1{font-size:46px}
  .anchor-band h2{font-size:32px}

  .florist-head h2{font-size:30px}
  .fleurop-text h3{font-size:24px}

  .benefits-grid{grid-template-columns:1fr}
  .cta-inner h2{font-size:28px}
  .cta-buttons{flex-direction:column}
  .cta-buttons a{justify-content:center}

  .foot-top{grid-template-columns:1fr;gap:22px}
  .foot-top .logo img{height:56px}
}

/* ═══════════════════════════════════════════════════════════════
   SMALL MOBILE (≤ 420px)
   ═══════════════════════════════════════════════════════════════ */
@media (max-width:420px){
  .wrap{padding:0 14px}

  .nav-inner{padding:0 10px 0 14px;gap:8px}
  .logo img{height:42px}
  .nav-cta{padding:9px 13px;font-size:12.5px}

  .hero h1{font-size:46px;letter-spacing:-.03em}
  .hero h1 .b{font-size:.88em}
  .hero p.lede{font-size:15.5px}
  .pill{font-size:11.5px;padding:7px 12px}
  .hero-art{height:240px}
  .hero-art .ill svg{width:180px}

  .section-head h2{font-size:30px}
  .card,.card-2,.card-3,.card-4{padding:24px;border-radius:24px}
  .card h3{font-size:22px}
  .card-rouw{padding:26px;border-radius:28px}
  .card-rouw h3{font-size:28px}

  .trust-inner{grid-template-columns:1fr;gap:10px}
  .trust-cell{min-height:auto;padding:22px;flex-direction:row;align-items:center;justify-content:space-between;gap:14px}
  .trust-cell .n{font-size:42px}
  .trust-cell .l{max-width:none;text-align:right}

  .delivery-scene .sky-text{font-size:24px}
  .mid-marquee .track{font-size:26px}
  .bot-marquee .track{font-size:17px}

  .shead h1{font-size:40px}
  .anchor-band h2{font-size:28px}
  .florist-head h2{font-size:26px}

  .page-hero h1{font-size:38px}
  .form-card{padding:22px 18px}
  .benefit p{font-size:13px}
  .cta-inner h2{font-size:24px}
}
