/* ============================================================
   Atelier Jowy — design system (v3, 1:1 mobiel ontwerp)
   Bordeaux #670d24 · Rood #ff6234 · Roze #ffc9ff
   Groen #e2f871 · Lichtblauw #b2c6ff · Wit #fff · Beige #f8f5f1
   Titels: MADE Mirage · Body: Poppins
   ============================================================ */

@font-face{font-family:'MADE Mirage';src:url('/assets/fonts/MADEMirage-Thin.woff2') format('woff2');font-weight:200;font-style:normal;font-display:swap}
@font-face{font-family:'MADE Mirage';src:url('/assets/fonts/MADEMirage-Regular.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'MADE Mirage';src:url('/assets/fonts/MADEMirage-Medium.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'MADE Mirage';src:url('/assets/fonts/MADEMirage-Bold.woff2') format('woff2');font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:'MADE Mirage';src:url('/assets/fonts/MADEMirage-Black.woff2') format('woff2');font-weight:900;font-style:normal;font-display:swap}

:root{
  --bordeaux:#670d24; --red:#ff6234; --pink:#ffc9ff; --green:#e2f871;
  --blue:#b2c6ff; --white:#fff; --ink:#1c1413; --beige:#f8f5f1;
  --maxw:1180px;
  --serif:'MADE Mirage',Georgia,'Times New Roman',serif;
  --sans:'Poppins',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --ease:cubic-bezier(.22,1,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden}
body{font-family:var(--sans);color:var(--ink);background:var(--beige);line-height:1.6;font-size:16px;-webkit-font-smoothing:antialiased;overflow-x:hidden;width:100%;max-width:100%}
img,svg,video{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4,.serif{font-family:var(--serif);font-weight:400;line-height:1.1;letter-spacing:.005em}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.section{padding:clamp(40px,6vw,80px) 0;position:relative;overflow:hidden}
.lead{font-size:15px;font-weight:300;line-height:1.7}
strong{font-weight:600}
.eyebrow{font-family:var(--sans);font-weight:500;font-size:12px;letter-spacing:.2em;text-transform:uppercase;opacity:.7;margin-bottom:12px}

.btn{display:inline-flex;align-items:center;gap:.6em;font-family:var(--sans);font-weight:500;font-size:14px;padding:11px 24px;border:1.5px solid currentColor;border-radius:40px;cursor:pointer;transition:transform .3s var(--ease),background .3s,color .3s;background:transparent}
.btn:hover{transform:translateY(-2px)}
.btn-pill{background:#fff;color:var(--ink);border-color:#0001;box-shadow:0 2px 10px rgba(0,0,0,.1);font-size:13px}
.btn-fill{background:var(--bordeaux);color:#fff;border-color:var(--bordeaux)}
.btn-fill:hover{background:var(--red);border-color:var(--red)}
.btn-red{background:var(--red);color:#fff;border-color:var(--red)}
.btn-red:hover{background:var(--bordeaux);border-color:var(--bordeaux)}

/* ---- Header: logo + hamburger ---- */
.header{position:sticky;top:0;z-index:60;background:var(--pink)}
.header-in{display:flex;align-items:center;justify-content:space-between;height:72px;max-width:var(--maxw);margin:0 auto;padding:0 22px}
.brand{font-family:var(--serif);font-weight:700;font-size:25px;color:var(--red);letter-spacing:.01em}
.hamburger{background:none;border:none;cursor:pointer;width:44px;height:44px;display:flex;flex-direction:column;justify-content:center;gap:6px;padding:9px}
.hamburger span{display:block;height:2.5px;background:var(--bordeaux);border-radius:2px;transition:.3s var(--ease)}

/* ---- Fullscreen menu ---- */
.menu{position:fixed;inset:0;z-index:90;background:var(--red);color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;opacity:0;pointer-events:none;transform:scale(1.04);transition:opacity .4s var(--ease),transform .4s var(--ease)}
.menu.open{opacity:1;pointer-events:auto;transform:scale(1)}
.menu-top{position:absolute;top:0;left:0;right:0;height:72px;display:flex;align-items:center;justify-content:space-between;padding:0 22px}
.menu-top .brand{color:#fff}
.menu-close{background:none;border:none;color:#fff;cursor:pointer;font-size:32px;line-height:1;width:44px;height:44px}
.menu nav{display:flex;flex-direction:column;align-items:center;gap:clamp(22px,4vw,34px)}
.menu nav a{font-family:var(--serif);font-size:clamp(34px,6vw,48px);position:relative;opacity:0;transform:translateY(20px);transition:opacity .5s var(--ease),transform .5s var(--ease)}
.menu.open nav a{opacity:1;transform:none}
.menu.open nav a:nth-child(1){transition-delay:.06s}
.menu.open nav a:nth-child(2){transition-delay:.13s}
.menu.open nav a:nth-child(3){transition-delay:.2s}
.menu nav a::after{content:"";position:absolute;left:50%;bottom:.02em;width:0;height:2px;background:currentColor;transform:translateX(-50%);transition:width .35s var(--ease)}
.menu nav a:hover::after,.menu nav a[aria-current="page"]::after{width:115%}
.menu-logo{position:absolute;bottom:8%;width:78px;opacity:0;transition:opacity .6s .35s}
.menu.open .menu-logo{opacity:1}

/* ---- Flowers ---- */
.flower{position:absolute;width:96px;transition:transform .5s var(--ease);transform-origin:center;z-index:4;will-change:transform}
.flower:hover{transform:rotate(120deg) scale(1.12)}
.flower.spin:hover{animation:spin 3s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---- Marquee ---- */
.marquee{background:var(--bordeaux);padding:22px 0;overflow:hidden}
.marquee-track{display:flex;width:max-content;gap:56px;animation:marquee 32s linear infinite;align-items:center}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee-track img{height:34px;width:auto;opacity:.95;flex:0 0 auto}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ---- Reveal ---- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}
@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ---- Wavy white frame (La Léa) ---- */
.framed{position:relative;padding:6% 7%;max-width:230px;margin:0 auto}
.framed::before{content:"";position:absolute;inset:0;background:url('/assets/brand/frame-line-white.svg') center/100% 100% no-repeat;z-index:0}
.framed img{position:relative;z-index:1;width:100%}
/* La Léa frame compact houden (win van .featured-media/.proj-media max-width) */
.featured-media.framed{max-width:225px}
.proj-media.framed{max-width:300px}

/* ---- Scallop panel (brand frame als schaalbare bg) ---- */
.scallop{position:relative;padding:clamp(26px,5vw,42px)}
.scallop>*{position:relative;z-index:1}
.scallop::before{content:"";position:absolute;inset:0;background:var(--frm) center/100% 100% no-repeat;z-index:0}

/* ============================================================
   HOME
   ============================================================ */
.hero{background:var(--blue);padding:clamp(36px,5vw,72px) 0}
.hero-grid{display:grid;grid-template-columns:1fr;gap:34px;align-items:center}
.hero h1{font-size:clamp(34px,5.2vw,52px);font-weight:400;line-height:1.14;margin-bottom:20px}
.hero p{max-width:46ch;margin-bottom:14px}
.hero-photos{position:relative;max-width:440px;justify-self:center;width:100%}
.photo-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;transition:gap .5s var(--ease)}
.photo-grid img{width:100%;aspect-ratio:3/4;object-fit:cover;filter:grayscale(1);border-radius:3px;transition:transform .5s var(--ease);will-change:transform}
.hero-flower{position:absolute;left:50%;top:50%;width:clamp(110px,16vw,160px);transform:translate(-50%,-50%);z-index:4;pointer-events:none}
.hero-flower img{width:100%;transition:transform .6s var(--ease);will-change:transform}
.hero-sign{position:absolute;left:6%;bottom:-26px;width:120px;z-index:5}
/* foto's uit elkaar + bloem-effect */
.hero-photos.photos-spread .photo-grid{gap:14px}
.hero-photos.photos-spread .photo-grid img:nth-child(1){transform:translate(-7px,-7px)}
.hero-photos.photos-spread .photo-grid img:nth-child(2){transform:translate(7px,-7px)}
.hero-photos.photos-spread .photo-grid img:nth-child(3){transform:translate(-7px,7px)}
.hero-photos.photos-spread .photo-grid img:nth-child(4){transform:translate(7px,7px)}
@media(hover:hover) and (pointer:fine){
  .hero-photos:hover .photo-grid{gap:14px}
  .hero-photos:hover .photo-grid img:nth-child(1){transform:translate(-7px,-7px)}
  .hero-photos:hover .photo-grid img:nth-child(2){transform:translate(7px,-7px)}
  .hero-photos:hover .photo-grid img:nth-child(3){transform:translate(-7px,7px)}
  .hero-photos:hover .photo-grid img:nth-child(4){transform:translate(7px,7px)}
  .hero-photos:hover .hero-flower img{animation:spin 3s linear infinite}
}

.services{background:var(--green);padding:16px 0;overflow:hidden}
.services-marquee{overflow:hidden}
.services-track{display:flex;width:max-content;animation:marquee 19s linear infinite}
.services-marquee:hover .services-track{animation-play-state:paused}
.services-set{display:flex;align-items:center;gap:16px;font-family:var(--serif);font-size:clamp(19px,5.2vw,24px);padding-right:16px;white-space:nowrap;flex:0 0 auto}
.services-set .sep{width:21px;height:21px;flex:0 0 auto}
@media(min-width:820px){
  .services-track{width:100%;justify-content:center;animation:none}
  .services-set{flex-wrap:wrap;justify-content:center;white-space:normal;gap:8px 16px;font-size:clamp(18px,2.2vw,22px);padding-right:0}
  .services-set.dup{display:none}
  .services-set .sep-trail{display:none}
}

.featured{background:var(--pink);position:relative;z-index:2;overflow:visible}
.featured-grid{display:grid;grid-template-columns:1fr;gap:30px;align-items:center}
.featured-media{position:relative;max-width:430px;justify-self:center;width:100%}
.featured h2{font-size:clamp(28px,4.4vw,42px);margin-bottom:18px;font-weight:400}
.featured p{margin-bottom:14px;font-size:15px;line-height:1.7;color:#3a2f2c}
.featured .flower{right:-26px;bottom:-46px;width:120px;z-index:5}

/* Reviews */
.reviews{background:var(--red);color:#fff;position:relative;z-index:1}
.reviews h2{text-align:center;font-size:clamp(26px,4.4vw,46px);max-width:none;margin:0 auto clamp(30px,4vw,48px);font-weight:400;line-height:1.16}
.review-stage{position:relative;max-width:1120px;margin:0 auto;padding:0 44px}
.review-slide{display:none;grid-template-columns:1fr;gap:14px;align-items:stretch}
.review-slide.active{display:grid;animation:fadeIn .5s var(--ease)}
.review-slide .scallop{display:flex;flex-direction:column;justify-content:center;height:100%;padding:16% 27%}
.review-quote{margin:0 auto;text-align:center}
.review-quote p{font-size:12.5px;line-height:1.5;color:var(--ink);margin-bottom:10px}
.review-quote .who{display:block;margin-top:14px;font-family:var(--serif);font-size:15px;color:var(--bordeaux)}
.review-img{border-radius:8px;overflow:hidden;aspect-ratio:3/4}
.review-img img{width:100%;height:100%;object-fit:cover}
.review-arrow{position:absolute;top:50%;transform:translateY(-50%);width:42px;height:42px;border:none;background:transparent;color:#fff;font-size:40px;line-height:0;cursor:pointer;opacity:.85;transition:opacity .25s,transform .25s}
.review-arrow:hover{opacity:1;transform:translateY(-50%) scale(1.12)}
.review-arrow.prev{left:-6px}.review-arrow.next{right:-6px}

/* Get in touch (roze) */
.git-section{background:var(--pink);text-align:center;padding:clamp(40px,6vw,72px) 0 30px}
.git-section .socials{display:flex;justify-content:center;gap:14px;margin-bottom:22px}
.git-section .socials a{width:44px;height:44px;border-radius:50%;background:var(--bordeaux);color:#fff;display:flex;align-items:center;justify-content:center;transition:.3s var(--ease)}
.git-section .socials a:hover{transform:translateY(-3px) rotate(-6deg);background:var(--red)}
.git{font-family:var(--serif);font-size:clamp(58px,15vw,150px);line-height:.92;color:var(--ink);display:inline-block;max-width:100%;transition:transform .4s var(--ease)}
.git:hover{transform:scale(1.02)}
.git-mail{display:inline-block;margin-top:10px;font-size:16px}
.git-mail:hover{color:var(--red)}
.git-rule{height:1.5px;background:var(--ink);opacity:.5;max-width:var(--maxw);margin:30px auto 0;width:calc(100% - 44px)}
.git-foot{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:#7a5a63;margin-top:18px}

/* ============================================================
   PORTFOLIO
   ============================================================ */
.proj{padding:clamp(40px,6vw,84px) 0;position:relative}
.proj-grid{display:grid;grid-template-columns:1fr;gap:30px;align-items:center}
.proj-grid.flip .proj-media{order:-1}
.proj .bartitle{font-family:var(--serif);font-weight:400;font-size:clamp(24px,3.6vw,34px);margin-bottom:16px}
.proj p{font-size:15px;line-height:1.7}
.wordmark-img{height:30px;width:auto;opacity:.9;margin-top:22px}
.proj-media{position:relative;justify-self:center;width:100%;max-width:500px}
.proj-media>img{width:100%;border-radius:8px}
.phones{display:flex;gap:14px;justify-content:center;flex-wrap:nowrap}
.phones .phone-frame{flex:1 1 0;max-width:210px;min-width:0}
.phone-frame{position:relative;padding:12% 13%}
.phone-frame::before{content:"";position:absolute;inset:0;z-index:0;background:var(--frm) center/100% 100% no-repeat}
.phone-frame.f-green{--frm:url('/assets/brand/frame-green.svg')}
.phone-frame.f-blue{--frm:url('/assets/brand/frame-blue.svg')}
.phone-frame.f-pink{--frm:url('/assets/brand/frame-pink.svg')}
.phone-frame.f-bordeaux{--frm:url('/assets/brand/frame-bordeaux.svg')}
.phone{position:relative;z-index:1;border:6px solid #111;border-radius:24px;overflow:hidden;background:#111;aspect-ratio:9/19.5;box-shadow:0 12px 28px rgba(0,0,0,.25)}
.phone video,.phone img{width:100%;height:100%;object-fit:cover}
.phone-ph{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:#fff;background:linear-gradient(150deg,var(--bordeaux),var(--red))}
.phone-ph img{width:46%;height:auto;opacity:.85}
.phone-ph span{font-size:11px;letter-spacing:.14em;text-transform:uppercase;opacity:.8}
.bg-pattern{position:absolute;inset:0;z-index:0;background-repeat:repeat;opacity:.45;pointer-events:none}
.proj>.wrap{position:relative;z-index:1}

/* ============================================================
   ANSICHTKAARTEN (platte kaartgrid)
   ============================================================ */
.kaart-intro{display:grid;grid-template-columns:1fr;gap:30px;align-items:start}
.kaart-intro .price-list li{list-style:none;margin:3px 0;font-size:15px}
.kaart-mock{position:relative;max-width:420px;justify-self:center}
.kaart-mock img{width:100%}
.kaart-mock{position:relative}
.kaart-mock>img:not(.flower){position:relative;z-index:2}
.kaart-mock .flower{width:clamp(150px,20vw,215px);top:-40px;right:-30px;z-index:1}
.note{font-size:13px;opacity:.7}
.card-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.card{display:block;border-radius:4px;overflow:hidden;background:#fff;padding:6px;box-shadow:0 5px 16px rgba(0,0,0,.1);transition:transform .45s var(--ease),box-shadow .45s var(--ease)}
.card:hover{transform:scale(1.07);box-shadow:0 18px 40px rgba(0,0,0,.2);z-index:2}
.card img{width:100%;aspect-ratio:1/1.41;object-fit:cover;border-radius:2px}
.price-strip{background:var(--bordeaux);color:#fff;text-align:center;padding:15px;font-family:var(--serif);font-size:clamp(14px,2.2vw,20px);display:flex;flex-wrap:wrap;gap:6px 14px;align-items:center;justify-content:center}
.price-strip img{width:18px}
.price-strip small{font-family:var(--sans);font-size:.6em;opacity:.85;font-weight:300}

.order{background:var(--bordeaux);color:#fff;position:relative}
.order-grid{display:grid;grid-template-columns:1fr;gap:30px;align-items:center}
.order .flower{width:clamp(110px,15vw,150px);top:-30px;left:-14px}
.order h2{font-size:clamp(28px,4.4vw,42px);margin-bottom:16px;font-weight:400}
.order .ig{width:26px;height:26px;display:inline-flex;margin-top:18px}
.order .sign{width:130px;margin-top:8px}

/* ============================================================
   DIENSTEN
   ============================================================ */
.dienst{padding:clamp(42px,6vw,84px) 0;position:relative;overflow:hidden}
.dienst-head{text-align:center;font-size:clamp(28px,4vw,42px);font-weight:400;margin-bottom:clamp(28px,5vw,48px)}
.dienst-row{display:grid;grid-template-columns:1fr;gap:34px;align-items:center;justify-items:center;position:relative;z-index:1}
.dienst-card{position:relative;max-width:430px;width:100%;text-align:center}
.dienst-card.scallop{padding:clamp(36px,6vw,54px) clamp(30px,6vw,46px)}
.dienst-card.ink{color:var(--ink)}
.dienst-card.white{color:#fff}
.dienst-card .c-title{font-family:var(--serif);font-size:clamp(22px,3.4vw,30px);margin-bottom:14px;font-weight:400}
.dienst-card p{font-size:14px;line-height:1.65;margin-bottom:16px}
.dienst-card ul{list-style:none;font-size:14px;line-height:1.95}
.dienst-ill{position:absolute;width:clamp(78px,13vw,116px);z-index:3;pointer-events:none}
.dienst-aside{position:relative;justify-self:center;display:flex;flex-direction:column;align-items:center;gap:16px}
.dienst-aside .phone-frame{max-width:210px}
.wordmark-serif{font-family:var(--serif);color:#fff;text-align:center;letter-spacing:.16em;line-height:1.3;font-size:clamp(20px,3vw,26px)}
.wordmark-serif small{display:block;font-size:.46em;letter-spacing:.26em;opacity:.85;margin-top:4px}
.dienst-cta{background:var(--pink);text-align:center;padding:clamp(40px,6vw,68px) 0}
.dienst-cta h2{font-size:clamp(26px,4.4vw,40px);font-weight:400;max-width:16ch;margin:0 auto 24px}

/* behind the scenes slider */
.bts{background:var(--bordeaux);color:#fff;position:relative;padding:clamp(38px,5vw,64px) 0}
.bts-stage{position:relative;max-width:var(--maxw);margin:0 auto;padding:0 46px}
.bts-track{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;-ms-overflow-style:none;scrollbar-width:none;scroll-behavior:smooth}
.bts-track::-webkit-scrollbar{display:none}
.bts-track img{flex:0 0 auto;width:min(74vw,300px);aspect-ratio:3/4;object-fit:cover;border-radius:8px;scroll-snap-align:center}
.bts-cap{text-align:center;font-family:var(--serif);margin-top:18px;opacity:.85;font-size:17px}
.bts-arrow{position:absolute;top:calc(50% - 16px);transform:translateY(-50%);width:40px;height:40px;border:none;background:transparent;color:#fff;font-size:38px;line-height:0;cursor:pointer;opacity:.85;transition:opacity .25s,transform .25s;z-index:2}
.bts-arrow:hover{opacity:1;transform:translateY(-50%) scale(1.12)}
.bts-arrow.prev{left:2px}.bts-arrow.next{right:2px}

@media(min-width:820px){
  /* kaart gecentreerd, aside als accent rechts (zoals het ontwerp) */
  .dienst-row{grid-template-columns:1fr;justify-items:center;max-width:900px;margin-left:auto;margin-right:auto;position:relative}
  .dienst-aside{position:absolute;top:50%;right:-6px;transform:translateY(-50%);width:250px;margin:0}
  .dienst-aside .phone,.dienst-aside .phone-frame{max-width:170px}
}

/* simpele footer (subpagina's zonder eigen git) */
.footer{background:var(--pink);text-align:center;padding:40px 0 30px}

@media(min-width:820px){
  .hero-grid{grid-template-columns:1.05fr .95fr}
  .featured-grid{grid-template-columns:.92fr 1.08fr}
  .review-slide{grid-template-columns:1.2fr .8fr}
  .proj-grid{grid-template-columns:1fr 1fr;gap:46px}
  .kaart-intro{grid-template-columns:1fr .9fr}
  .card-grid{grid-template-columns:repeat(4,1fr);gap:18px}
  .order-grid{grid-template-columns:1.2fr .8fr}
}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .marquee-track{animation:none}
}
