/* ============================================================
   Noémie Sorel — Portfolio
   Apple Vision Pro inspired · white & grey · glassmorphism
   ============================================================ */

:root{
  /* palette — white & grey only */
  --bg-0:#eceef1;
  --bg-1:#f4f5f7;
  --ink:#1c1d21;
  --ink-soft:#5b5e66;
  --ink-faint:#9a9da6;
  --line:rgba(28,29,33,.10);

  /* glass */
  --glass:rgba(255,255,255,.55);
  --glass-strong:rgba(255,255,255,.66);
  --glass-soft:rgba(255,255,255,.38);
  --glass-brd:rgba(255,255,255,.7);
  --glass-blur:saturate(180%) blur(34px);

  /* depth shadows (vision pro = soft, layered, floating) */
  --float:
     0 1px 0 rgba(255,255,255,.6) inset,
     0 24px 60px -20px rgba(40,44,55,.35),
     0 6px 18px -8px rgba(40,44,55,.20);
  --float-lg:
     0 1px 0 rgba(255,255,255,.65) inset,
     0 50px 110px -30px rgba(34,38,48,.45),
     0 14px 40px -16px rgba(34,38,48,.28);

  --r-lg:34px;
  --r-md:24px;
  --r-sm:16px;
  --ease:cubic-bezier(.22,.61,.36,1);

  font-family:"Geist",-apple-system,BlinkMacSystemFont,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth; overflow-x:hidden; width:100%}
body{
  background:
     radial-gradient(120% 90% at 80% -10%, #fbfbfd 0%, rgba(251,251,253,0) 55%),
     radial-gradient(100% 80% at 0% 100%, #e6e8ec 0%, rgba(230,232,236,0) 60%),
     linear-gradient(180deg,var(--bg-1),var(--bg-0));
  color:var(--ink);
  min-height:100vh;
  width:100%; max-width:100%;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
}

/* ---------- background canvas + grain ---------- */
#bg-canvas{
  position:fixed; inset:0; width:100%; height:100%;
  z-index:0; pointer-events:none; opacity:.9;
}
.grain{
  position:fixed; inset:0; z-index:1; pointer-events:none;
  opacity:.05; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* clip horizontal overflow from the absolutely-positioned hero slides
   so mobile browsers never widen the layout viewport (which would flip
   the nav back to its desktop layout) */
main{position:relative; z-index:2; overflow-x:clip}

/* ---------- typography ---------- */
.display{
  font-family:"Fraunces",serif;
  font-weight:380;
  font-optical-sizing:auto;
  letter-spacing:-.018em;
  line-height:.96;
  font-size:clamp(2.8rem,8vw,6.6rem);
}
.display em{font-style:italic; font-weight:340}
.display.sm{font-size:clamp(2.2rem,5vw,3.8rem); line-height:.98}

.eyebrow{
  font-size:.74rem; letter-spacing:.32em; text-transform:uppercase;
  color:var(--ink-faint); font-weight:500;
}

/* =========================================================
   NAV
   ========================================================= */
.nav{
  position:fixed; top:18px; left:50%; transform:translateX(-50%);
  z-index:50;
  width:min(1180px,calc(100% - 32px));
  display:flex; align-items:center; gap:18px;
  padding:9px 9px 9px 20px;
  background:var(--glass); backdrop-filter:var(--glass-blur);
  -webkit-backdrop-filter:var(--glass-blur);
  border:1px solid var(--glass-brd);
  border-radius:100px;
  box-shadow:var(--float);
  transition:top .5s var(--ease), box-shadow .4s var(--ease);
}
.nav.shrink{box-shadow:var(--float-lg)}

.brand{display:flex; align-items:center; gap:11px; text-decoration:none; color:var(--ink)}
.brand-mark{
  width:26px; height:26px; border-radius:50%;
  background:
    radial-gradient(circle at 32% 30%, #fff, rgba(255,255,255,0) 45%),
    conic-gradient(from 200deg, #c9ccd4, #8d919c, #d7d9df, #aeb1bb, #c9ccd4);
  box-shadow:0 2px 8px rgba(0,0,0,.18), 0 0 0 1px rgba(255,255,255,.6) inset;
}
.brand-name{
  font-family:"Fraunces",serif; font-weight:480; font-size:1.06rem;
  letter-spacing:-.01em; white-space:nowrap;
}

.seg{
  position:relative; display:flex; margin:0 auto; gap:2px;
  padding:4px; border-radius:100px;
  background:rgba(255,255,255,.35);
  border:1px solid rgba(255,255,255,.5);
}
.seg-item{
  position:relative; z-index:2;
  padding:8px 17px; border-radius:100px;
  font-size:.86rem; font-weight:450; color:var(--ink-soft);
  text-decoration:none; white-space:nowrap;
  transition:color .35s var(--ease);
}
.seg-item.is-active{color:var(--ink)}
.seg-pill{
  position:absolute; z-index:1; top:4px; left:4px; height:calc(100% - 8px);
  background:var(--glass-strong);
  border:1px solid var(--glass-brd);
  border-radius:100px;
  box-shadow:0 4px 14px -4px rgba(40,44,55,.3), 0 1px 0 rgba(255,255,255,.7) inset;
  transition:transform .45s var(--ease), width .45s var(--ease);
}

.nav-cta{
  display:inline-flex; align-items:center; gap:7px;
  padding:10px 18px; border-radius:100px; text-decoration:none;
  font-size:.86rem; font-weight:500; color:#fff;
  background:linear-gradient(180deg,#3a3c44,#222329);
  box-shadow:0 6px 18px -6px rgba(34,35,41,.6), 0 1px 0 rgba(255,255,255,.18) inset;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease);
  white-space:nowrap;
}
.nav-cta:hover{transform:translateY(-1px); box-shadow:0 10px 26px -8px rgba(34,35,41,.7)}
.nav-cta svg{transition:transform .3s var(--ease)}
.nav-cta:hover svg{transform:translateX(3px)}

/* =========================================================
   HERO
   ========================================================= */
.hero{
  min-height:100vh;
  padding:148px 24px 60px;
  display:flex; flex-direction:column; align-items:center;
  text-align:center;
}
.hero-head{max-width:880px}
.hero .lede{
  max-width:540px; margin:22px auto 0;
  color:var(--ink-soft); font-size:1.06rem; font-weight:350;
}
.hero h1{margin-top:18px}

/* collection switcher */
.collections{
  position:relative; display:inline-flex; gap:3px; margin:34px auto 30px;
  padding:5px; border-radius:100px;
  background:var(--glass); backdrop-filter:var(--glass-blur);
  -webkit-backdrop-filter:var(--glass-blur);
  border:1px solid var(--glass-brd);
  box-shadow:var(--float);
}
.col-item{
  position:relative; z-index:2; border:0; background:none; cursor:pointer;
  padding:10px 22px; border-radius:100px;
  font-family:inherit; font-size:.9rem; font-weight:450; color:var(--ink-soft);
  transition:color .35s var(--ease);
}
.col-item.is-active{color:var(--ink)}
.col-pill{
  position:absolute; z-index:1; top:5px; left:5px; height:calc(100% - 10px);
  background:var(--glass-strong); border:1px solid var(--glass-brd);
  border-radius:100px;
  box-shadow:0 5px 16px -5px rgba(40,44,55,.32), 0 1px 0 rgba(255,255,255,.7) inset;
  transition:transform .5s var(--ease), width .5s var(--ease);
}

/* ---- 3D coverflow ---- */
.carousel{
  position:relative; width:100%; max-width:1180px;
  perspective:1600px;
  margin-top:6px;
  user-select:none;
  touch-action:pan-y;          /* vertical swipe scrolls page, horizontal scrubs */
}
.stage{
  position:relative; height:clamp(380px,54vh,560px);
  transform-style:preserve-3d;
  display:flex; align-items:center; justify-content:center;
}
.slide{
  position:absolute; top:50%; left:50%;
  width:clamp(260px,30vw,360px); aspect-ratio:4/5;
  margin:-1px 0 0;
  border-radius:var(--r-md);
  overflow:hidden; cursor:pointer;
  background:#dfe1e6;
  border:1px solid rgba(255,255,255,.55);
  box-shadow:var(--float-lg);
  will-change:transform,opacity;
  transform-style:preserve-3d;
  transition:opacity .5s var(--ease), box-shadow .5s var(--ease), filter .7s var(--ease);
}
/* inner layer tilts toward the cursor, independent of the coverflow position */
.slide-inner{
  position:absolute; inset:0; border-radius:inherit;
  transform-style:preserve-3d; will-change:transform;
  transition:transform .7s var(--ease);
}
.slide img{
  width:100%; height:100%; object-fit:cover; display:block;
  filter:grayscale(.32) contrast(1.03) brightness(1.01);
  transition:filter .7s var(--ease), transform 8s var(--ease);
}
.slide::after{ /* glass sheen */
  content:""; position:absolute; inset:0; border-radius:inherit;
  background:linear-gradient(125deg,rgba(255,255,255,.28),rgba(255,255,255,0) 38%);
  pointer-events:none;
}
.slide.is-active img{filter:grayscale(.05) contrast(1.05)}
.slide.is-active{cursor:grab}

.carousel-ui{
  position:relative; z-index:5; margin-top:26px;
  display:flex; align-items:center; justify-content:center; gap:18px;
}
.cbtn{
  width:48px; height:48px; flex:none; border-radius:50%; cursor:pointer;
  display:grid; place-items:center; color:var(--ink);
  background:var(--glass); backdrop-filter:var(--glass-blur);
  -webkit-backdrop-filter:var(--glass-blur);
  border:1px solid var(--glass-brd); box-shadow:var(--float);
  transition:transform .3s var(--ease), background .3s var(--ease);
}
.cbtn:hover{transform:scale(1.07); background:var(--glass-strong)}
.cbtn:active{transform:scale(.96)}

.caption{
  min-width:240px; text-align:center;
  display:flex; flex-direction:column; gap:3px;
  padding:11px 26px; border-radius:100px;
  background:var(--glass-soft); backdrop-filter:var(--glass-blur);
  -webkit-backdrop-filter:var(--glass-blur);
  border:1px solid var(--glass-brd);
}
.caption-title{
  font-family:"Fraunces",serif; font-size:1.05rem; font-weight:450;
  letter-spacing:.04em;
}
.caption-meta{font-size:.72rem; color:var(--ink-faint); letter-spacing:.06em}

.scroll-hint{
  margin-top:40px; font-size:.74rem; letter-spacing:.22em; text-transform:uppercase;
  color:var(--ink-faint); display:flex; align-items:center; gap:10px;
}
.scroll-hint span{
  width:1px; height:34px; display:block;
  background:linear-gradient(var(--ink-faint),transparent);
  animation:drip 2.2s var(--ease) infinite;
}
@keyframes drip{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* =========================================================
   SECTIONS
   ========================================================= */
.section{padding:90px 24px; max-width:1180px; margin:0 auto}
.section-head{max-width:620px; margin-bottom:48px}
.section-head h2{margin:14px 0}
.section-note,.about-body p,.contact-left p{color:var(--ink-soft); font-weight:350}

/* glass utilities */
.glass{
  background:var(--glass); backdrop-filter:var(--glass-blur);
  -webkit-backdrop-filter:var(--glass-blur);
  border:1px solid var(--glass-brd); box-shadow:var(--float-lg);
}
.glass-soft{
  background:var(--glass-soft); backdrop-filter:var(--glass-blur);
  -webkit-backdrop-filter:var(--glass-blur);
  border:1px solid var(--glass-brd); box-shadow:var(--float);
}

/* ---- gallery grid ---- */
.grid{
  display:grid; grid-template-columns:repeat(12,1fr);
  grid-auto-rows:14px; gap:18px;
}
.tile{
  position:relative; overflow:hidden; border-radius:var(--r-md);
  border:1px solid rgba(255,255,255,.5);
  box-shadow:var(--float); cursor:pointer;
  background:#dfe1e6;
  transform-style:preserve-3d; will-change:transform;
  transition:transform .6s var(--ease), box-shadow .5s var(--ease);
}
.tile:hover{box-shadow:var(--float-lg)}
.tile img{
  width:100%; height:100%; object-fit:cover; display:block;
  filter:grayscale(.4) contrast(1.03);
  transition:transform 1.1s var(--ease), filter .7s var(--ease);
}
.tile:hover img{transform:scale(1.06); filter:grayscale(.02) contrast(1.06)}
/* light reflection that tracks the cursor (Vision Pro glass sheen) */
.glare{
  position:absolute; inset:0; border-radius:inherit; z-index:3;
  pointer-events:none; opacity:0; mix-blend-mode:soft-light;
  transition:opacity .45s var(--ease);
  background:radial-gradient(220px circle at var(--mx,50%) var(--my,50%),
            rgba(255,255,255,.85), rgba(255,255,255,.15) 40%, rgba(255,255,255,0) 65%);
}
.tile:hover .glare,.proc:hover .glare,.slide:hover .glare{opacity:1}
.tile::after{
  content:attr(data-label);
  position:absolute; left:16px; bottom:14px; z-index:4;
  font-family:"Fraunces",serif; font-size:.95rem; letter-spacing:.03em;
  color:#fff; text-shadow:0 2px 12px rgba(0,0,0,.5);
  opacity:0; transform:translateY(8px); transition:.5s var(--ease);
}
.tile:hover::after{opacity:1; transform:none}

/* =========================================================
   LANDSCAPES — horizontal scroll strip
   ========================================================= */
.land{max-width:none; padding-left:0; padding-right:0; overflow:hidden}
.land-head{max-width:620px; padding:0 24px; margin:0 auto 40px}
.land-scroller{
  position:relative;
  overflow-x:auto; overflow-y:hidden;
  scrollbar-width:none; -ms-overflow-style:none;
  cursor:grab;
  perspective:1500px;
  touch-action:pan-x;                    /* allow native horizontal swipe */
  -webkit-overflow-scrolling:touch;      /* momentum scroll on iOS */
}
.land-scroller::-webkit-scrollbar{display:none}
.land-scroller.dragging{cursor:grabbing}
.land-track{
  display:flex; gap:22px; padding:14px 24px 8px;
  width:max-content;
}
.land-card{
  position:relative; flex:none;
  width:clamp(280px,38vw,520px); aspect-ratio:16/11;
  border-radius:var(--r-lg); overflow:hidden;
  border:1px solid rgba(255,255,255,.55);
  box-shadow:var(--float-lg);
  transform-style:preserve-3d; will-change:transform;
  transition:transform .7s var(--ease), box-shadow .5s var(--ease);
}
.land-card:nth-child(even){margin-top:34px}
.land-card:nth-child(3n){width:clamp(240px,28vw,400px)}
.land-card img{
  width:100%; height:100%; object-fit:cover; display:block;
  filter:grayscale(.42) contrast(1.04) brightness(1.02);
  transition:transform 1.4s var(--ease), filter .8s var(--ease);
}
.land-card:hover img{transform:scale(1.07); filter:grayscale(.05) contrast(1.07)}
.land-card:hover .glare{opacity:1}
.land-meta{
  position:absolute; left:18px; bottom:16px; z-index:4;
  display:flex; flex-direction:column; gap:2px;
  color:#fff; text-shadow:0 2px 16px rgba(0,0,0,.55);
  opacity:0; transform:translateY(10px); transition:.55s var(--ease);
}
.land-card:hover .land-meta{opacity:1; transform:none}
.land-meta b{font-family:"Fraunces",serif; font-weight:460; font-size:1.15rem; letter-spacing:.02em}
.land-meta span{font-size:.74rem; letter-spacing:.12em; text-transform:uppercase; opacity:.85}

.land-progress{
  position:relative; height:2px; margin:26px 24px 0;
  background:var(--line); border-radius:2px;
}
.land-progress span{
  position:absolute; left:0; top:0; height:100%; width:18%;
  background:linear-gradient(90deg,#9a9da6,#5b5e66);
  border-radius:2px; transition:width .12s linear, transform .12s linear;
}
.land-hint{
  margin:14px 24px 0; font-size:.72rem; letter-spacing:.2em;
  text-transform:uppercase; color:var(--ink-faint);
}

/* =========================================================
   ABOUT
   ========================================================= */
.about-card{
  border-radius:var(--r-lg);
  display:grid; grid-template-columns:.85fr 1.15fr; gap:0;
  overflow:hidden;
}
.about-portrait{position:relative; min-height:440px}
.about-portrait img{
  width:100%; height:100%; object-fit:cover; display:block;
  filter:grayscale(.25) contrast(1.04);
}
.about-badge{
  position:absolute; left:18px; bottom:18px;
  padding:8px 16px; border-radius:100px; font-size:.74rem;
  letter-spacing:.05em; color:var(--ink);
}
.about-body{padding:clamp(28px,4vw,52px); display:flex; flex-direction:column; gap:16px}
.about-body h2{margin:6px 0 4px}
.about-body p{font-size:1rem}
.about-body em{font-style:italic; color:var(--ink)}

.stats{display:flex; gap:30px; margin-top:14px; padding-top:22px; border-top:1px solid var(--line)}
.stat{display:flex; flex-direction:column}
.stat b{font-family:"Fraunces",serif; font-size:1.9rem; font-weight:420; line-height:1}
.stat span{font-size:.76rem; color:var(--ink-faint); letter-spacing:.08em; text-transform:uppercase; margin-top:4px}

.process{display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:18px}
.proc{
  position:relative; overflow:hidden; padding:26px 24px; border-radius:var(--r-md);
  transform-style:preserve-3d; will-change:transform;
  transition:transform .7s var(--ease), box-shadow .5s var(--ease);
}
.proc:hover{box-shadow:var(--float-lg)}
.proc > *:not(.glare){position:relative; z-index:2}
.proc-num{font-family:"Fraunces",serif; font-size:.9rem; color:var(--ink-faint)}
.proc h3{font-family:"Fraunces",serif; font-weight:460; font-size:1.25rem; margin:8px 0 8px}
.proc p{font-size:.92rem; color:var(--ink-soft); font-weight:350}

/* =========================================================
   CONTACT
   ========================================================= */
.contact-card{
  border-radius:var(--r-lg); padding:clamp(28px,4vw,54px);
  display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,5vw,64px);
  align-items:center;
}
.contact-left h2{margin:14px 0 16px}
.contact-left p{font-size:1.02rem}
.contact-links{list-style:none; margin-top:28px; display:flex; flex-direction:column; gap:14px}
.contact-links li{display:flex; flex-direction:column; gap:2px; padding-bottom:14px; border-bottom:1px solid var(--line)}
.contact-links span{font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-faint)}
.contact-links a{color:var(--ink); text-decoration:none; font-size:1.02rem; width:fit-content; transition:opacity .3s}
.contact-links a:hover{opacity:.55}

.contact-form{padding:clamp(22px,3vw,32px); border-radius:var(--r-md); display:flex; flex-direction:column; gap:15px}
.field{display:flex; flex-direction:column; gap:7px}
.field span{font-size:.74rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-faint)}
.field input,.field textarea,.field select{
  font-family:inherit; font-size:.95rem; color:var(--ink);
  padding:13px 15px; border-radius:14px;
  background:rgba(255,255,255,.5);
  border:1px solid rgba(255,255,255,.7);
  outline:none; transition:border .3s, background .3s, box-shadow .3s;
  width:100%; resize:none;
}
.field input::placeholder,.field textarea::placeholder{color:var(--ink-faint)}
.field input:focus,.field textarea:focus,.field select:focus{
  background:rgba(255,255,255,.75);
  border-color:rgba(120,124,134,.5);
  box-shadow:0 0 0 4px rgba(120,124,134,.12);
}
.select-wrap{position:relative}
.select-wrap select{appearance:none; cursor:pointer}
.select-wrap svg{position:absolute; right:14px; top:50%; transform:translateY(-50%); color:var(--ink-faint); pointer-events:none}

.submit{
  margin-top:6px; display:inline-flex; align-items:center; justify-content:center; gap:9px;
  padding:15px; border:0; border-radius:14px; cursor:pointer;
  font-family:inherit; font-size:.95rem; font-weight:500; color:#fff;
  background:linear-gradient(180deg,#3a3c44,#202127);
  box-shadow:0 10px 26px -10px rgba(34,35,41,.7), 0 1px 0 rgba(255,255,255,.18) inset;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease);
}
.submit:hover{transform:translateY(-2px); box-shadow:0 16px 34px -12px rgba(34,35,41,.8)}
.submit svg{transition:transform .3s var(--ease)}
.submit:hover svg{transform:translateX(3px)}
.form-ok{font-size:.86rem; color:var(--ink-soft); text-align:center; margin-top:4px}

/* =========================================================
   FOOTER
   ========================================================= */
.footer{
  max-width:1180px; margin:40px auto; padding:26px 28px;
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  border-top:1px solid var(--line); flex-wrap:wrap;
}
.footer .brand-name{font-size:1.15rem}
.footer-mid{font-size:.8rem; color:var(--ink-faint); text-align:center}
.footer-credit{
  color:var(--ink); text-decoration:none; font-weight:500;
  border-bottom:1px solid var(--line); transition:color .3s, border-color .3s;
}
.footer-credit:hover{color:#000; border-color:var(--ink)}
.to-top{color:var(--ink-soft); text-decoration:none; font-size:.85rem; transition:opacity .3s}
.to-top:hover{opacity:.55}

/* =========================================================
   BACK-TO-TOP — floating glass button
   ========================================================= */
.top-btn{
  position:fixed; z-index:60; right:22px; bottom:22px;
  width:52px; height:52px; border-radius:50%; cursor:pointer;
  display:grid; place-items:center; color:var(--ink);
  background:var(--glass); backdrop-filter:var(--glass-blur);
  -webkit-backdrop-filter:var(--glass-blur);
  border:1px solid var(--glass-brd); box-shadow:var(--float);
  opacity:0; transform:translateY(18px) scale(.85); pointer-events:none;
  transition:opacity .45s var(--ease), transform .45s var(--ease), background .3s var(--ease);
}
.top-btn.show{opacity:1; transform:none; pointer-events:auto}
.top-btn:hover{background:var(--glass-strong); transform:translateY(-2px)}
.top-btn:active{transform:scale(.94)}
.top-btn svg{transition:transform .3s var(--ease)}
.top-btn:hover svg{transform:translateY(-2px)}

@media (max-width:560px){
  .top-btn{right:16px; bottom:16px; width:46px; height:46px}
}

/* =========================================================
   COOKIE BANNER (RGPD) — floating glass, Vision-Pro style
   ========================================================= */
.cookie{
  position:fixed; z-index:80;
  left:50%; bottom:22px; transform:translateX(-50%) translateY(140%);
  width:min(720px,calc(100% - 32px));
  display:flex; align-items:center; gap:18px;
  padding:16px 18px;
  background:var(--glass); backdrop-filter:var(--glass-blur);
  -webkit-backdrop-filter:var(--glass-blur);
  border:1px solid var(--glass-brd);
  border-radius:24px; box-shadow:var(--float-lg);
  opacity:0; transition:transform .8s var(--ease), opacity .8s var(--ease);
}
.cookie[hidden]{display:flex}            /* keep it animatable */
.cookie.show{transform:translateX(-50%) translateY(0); opacity:1}
.cookie-icon{
  flex:none; width:44px; height:44px; border-radius:14px; display:grid; place-items:center;
  color:var(--ink-soft);
  background:rgba(255,255,255,.5); border:1px solid rgba(255,255,255,.7);
}
.cookie-body{flex:1; min-width:0}
.cookie-title{font-family:"Fraunces",serif; font-size:1rem; font-weight:480; margin-bottom:3px}
.cookie-text{font-size:.84rem; color:var(--ink-soft); font-weight:350; line-height:1.45}
.cookie-link{color:var(--ink); text-decoration:underline; text-underline-offset:2px}
.cookie-actions{display:flex; gap:9px; flex:none}
.cookie-btn{
  font-family:inherit; font-size:.84rem; font-weight:500; cursor:pointer;
  padding:11px 18px; border-radius:100px; white-space:nowrap;
  transition:transform .3s var(--ease), background .3s, box-shadow .3s;
}
.cookie-btn:hover{transform:translateY(-1px)}
.cookie-btn.ghost{
  color:var(--ink-soft); border:1px solid var(--glass-brd);
  background:rgba(255,255,255,.35);
}
.cookie-btn.ghost:hover{background:rgba(255,255,255,.6); color:var(--ink)}
.cookie-btn.solid{
  color:#fff; border:0;
  background:linear-gradient(180deg,#3a3c44,#202127);
  box-shadow:0 8px 20px -8px rgba(34,35,41,.65), 0 1px 0 rgba(255,255,255,.18) inset;
}
.cookie-btn.solid:hover{box-shadow:0 12px 26px -10px rgba(34,35,41,.75)}

@media (max-width:620px){
  .cookie{flex-direction:column; align-items:flex-start; text-align:left}
  .cookie-actions{width:100%}
  .cookie-btn{flex:1; text-align:center}
}

/* =========================================================
   REVEAL ANIM
   ========================================================= */
.reveal{opacity:0; transform:translateY(26px); transition:opacity 1s var(--ease), transform 1s var(--ease)}
.reveal.in{opacity:1; transform:none}
.reveal:nth-child(2){transition-delay:.08s}
.reveal:nth-child(3){transition-delay:.16s}

/* =========================================================
   VISION-PRO ANIMATIONS
   ========================================================= */
/* panels "materialize" — blur + scale in, like a window opening */
.vp-bloom{
  opacity:0; transform:scale(.95) translateY(26px); filter:blur(12px);
  transition:opacity 1s var(--ease), transform 1s var(--ease), filter 1s var(--ease);
}
.vp-bloom.in{opacity:1; transform:none; filter:blur(0)}

/* signature springy hover-lift on the segmented controls */
.seg-item,.col-item{transition:color .35s var(--ease), transform .4s var(--ease)}
.seg-item:hover,.col-item:hover:not(.is-active){transform:translateY(-1px) scale(1.04)}
.seg:hover .seg-pill,.collections:hover .col-pill{
  box-shadow:0 8px 22px -6px rgba(40,44,55,.4), 0 1px 0 rgba(255,255,255,.8) inset;
}

/* active slide breathes brighter when you hover it */
.slide.is-active:hover{box-shadow:var(--float-lg), 0 0 0 1px rgba(255,255,255,.7) inset}
.slide.is-active:hover img{filter:grayscale(0) contrast(1.07) brightness(1.04)}

/* glass controls get a soft specular bloom on hover */
.cbtn,.nav-cta,.caption{position:relative; overflow:hidden}
.cbtn::before,.nav-cta::before{
  content:""; position:absolute; inset:0; border-radius:inherit; opacity:0;
  background:radial-gradient(120% 120% at 50% 0%, rgba(255,255,255,.7), rgba(255,255,255,0) 60%);
  transition:opacity .4s var(--ease);
}
.cbtn:hover::before,.nav-cta:hover::before{opacity:1}

/* brand mark slowly turns, like a Vision Pro loader jewel */
.brand-mark{animation:spin 22s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* gentle float for the whole carousel stage */
.stage{animation:floaty 9s ease-in-out infinite}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

/* =========================================================
   RESPONSIVE
   ========================================================= */
/* mobile menu — hidden on desktop */
.nav-toggle{display:none}
.nav-menu{display:none}

@media (max-width:900px){
  .seg{display:none}
  .nav-cta{display:none}          /* Contact reste accessible via le menu burger */
  /* pin to both edges instead of centering — burger always on-screen */
  .nav{
    left:14px; right:14px; width:auto; transform:none;
    justify-content:space-between; gap:12px; padding:9px 10px 9px 18px;
  }
  .about-card{grid-template-columns:1fr}
  .about-portrait{min-height:340px}
  .contact-card{grid-template-columns:1fr}
  .process{grid-template-columns:1fr}

  /* burger button */
  .nav-toggle{
    display:flex; flex-direction:column; justify-content:center; gap:5px;
    width:44px; height:44px; flex:none; border:0; cursor:pointer; padding:0 12px;
    border-radius:50%; background:rgba(255,255,255,.4);
    border:1px solid var(--glass-brd);
  }
  .nav-toggle span{
    display:block; height:1.6px; width:18px; background:var(--ink); border-radius:2px;
    transition:transform .35s var(--ease), opacity .3s var(--ease);
  }
  .nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(3.3px) rotate(45deg)}
  .nav-toggle[aria-expanded="true"] span:nth-child(2){transform:translateY(-3.3px) rotate(-45deg)}

  /* dropdown panel */
  .nav-menu{
    position:fixed; z-index:49; top:78px; left:50%;
    transform:translateX(-50%) translateY(-12px) scale(.97);
    width:min(420px,calc(100% - 24px));
    display:flex; flex-direction:column;
    padding:10px; gap:2px;
    background:var(--glass); backdrop-filter:var(--glass-blur);
    -webkit-backdrop-filter:var(--glass-blur);
    border:1px solid var(--glass-brd); border-radius:26px; box-shadow:var(--float-lg);
    opacity:0; pointer-events:none; filter:blur(6px);
    transition:opacity .4s var(--ease), transform .4s var(--ease), filter .4s var(--ease);
  }
  .nav-menu.open{opacity:1; pointer-events:auto; filter:blur(0); transform:translateX(-50%) translateY(0) scale(1)}
  .nav-menu a{
    padding:14px 18px; border-radius:16px; text-decoration:none;
    color:var(--ink); font-size:1.02rem; font-family:"Fraunces",serif; font-weight:440;
    transition:background .25s var(--ease);
  }
  .nav-menu a:hover,.nav-menu a:active{background:rgba(255,255,255,.5)}
}
@media (max-width:560px){
  .caption{min-width:0}
  .hero{padding-top:120px}

  /* gallery → clean 2-column on phones (override inline spans) */
  .grid{grid-template-columns:repeat(2,1fr); grid-auto-rows:auto; gap:12px}
  .tile{grid-column:span 1 !important; grid-row:auto !important; aspect-ratio:4/5}

  /* keep the collection switcher on one line */
  .collections{max-width:calc(100% - 24px)}
  .col-item{padding:9px 13px; font-size:.8rem}

  .land-card:nth-child(even){margin-top:18px}
  .stats{gap:20px}
}

@media (prefers-reduced-motion:reduce){
  *{animation:none !important; transition-duration:.01ms !important}
  .reveal,.vp-bloom{opacity:1; transform:none; filter:none}
}
