/* ============================================================
   Flore Bretonnière — design system
   One shell, four times. Constant spine + time-thread (the unity);
   per-collection colour skin (the variation). Dark = Inner Cities only.
   ============================================================ */
:root{
  --serif:"Hoefler Text","Iowan Old Style","Palatino Linotype",Palatino,"Times New Roman",Georgia,"Songti SC","Hiragino Mincho ProN","Yu Mincho","Noto Serif CJK SC",serif;
  --grotesk:"Helvetica Neue",Helvetica,"Arial Nova",Arial,system-ui,"PingFang SC","Hiragino Sans","Yu Gothic","Noto Sans CJK SC",sans-serif;
  --mono:ui-monospace,"SF Mono","Menlo","Cascadia Mono","PingFang SC","Hiragino Sans",monospace;
  /* default (home) skin — warm light parchment */
  --ground:#e9e3d7; --ink:#211d17; --soft:#766c5c; --accent:#9c5436; --line:#d3c9b6; --mat:#f3eee4;
  --pad:clamp(22px,5vw,86px);
  --grain: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='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  --rail:270px;
}
*{box-sizing:border-box}
html,body{margin:0}
body{
  background:var(--ground); color:var(--ink);
  font-family:var(--grotesk); -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  transition:background-color .7s ease, color .7s ease;
}
body::before{ /* film grain — the analog/tungsten mood */
  content:""; position:fixed; inset:0; z-index:9; pointer-events:none;
  background-image:var(--grain); background-size:200px; opacity:.045; mix-blend-mode:multiply;
}
a{color:inherit; text-decoration:none}
img{display:block; max-width:100%}

#app{display:flex; min-height:100vh; align-items:stretch}

/* ---------------- SPINE (constant across all skins) ---------------- */
.spine{
  width:var(--rail); flex:0 0 var(--rail); position:sticky; top:0; align-self:flex-start;
  height:100vh; padding:34px 26px; display:flex; flex-direction:column; gap:26px;
  border-right:0; transition:border-color .7s ease;
}
.brand{font-family:var(--serif); font-size:22px; line-height:1.1; letter-spacing:.01em}
.brand a{display:block}
.brand small{display:block; font-family:var(--mono); font-size:9px; letter-spacing:.24em; text-transform:uppercase; color:var(--soft); margin-top:10px}

.idx{list-style:none; margin:0; padding:0; display:flex; flex-direction:column}
.idx-h{font-family:var(--mono); font-size:9.5px; letter-spacing:.24em; text-transform:uppercase; color:var(--soft); margin:0 0 10px}
.idx li a{display:grid; grid-template-columns:24px 1fr; gap:11px; padding:11px 0; align-items:baseline;
  border-bottom:1px solid transparent; transition:border-color .3s, color .3s}
.idx li a:hover{border-bottom-color:var(--line)}
.idx .n{font-family:var(--mono); font-size:11px; color:var(--accent); transition:color .7s ease}
.idx .cn{font-family:var(--serif); font-size:18px; line-height:1.12}
.idx .ct{display:block; font-family:var(--mono); font-size:9px; letter-spacing:.05em; text-transform:uppercase; color:var(--soft); margin-top:4px}
.idx li a.on .cn,.idx li a:hover .cn{color:var(--accent)}

.spine-nav{display:flex; flex-direction:column; gap:11px; font-family:var(--mono); font-size:12px; letter-spacing:.14em; text-transform:uppercase}
.spine-nav a{color:var(--ink); opacity:.6; transition:opacity .3s}
.spine-nav a:hover,.spine-nav a.on{opacity:1}

.spine-foot{margin-top:auto; display:flex; flex-direction:column; gap:16px}
.lang{display:inline-flex; border:1px solid var(--line); border-radius:30px; overflow:hidden; width:max-content; transition:border-color .7s}
.lang button{appearance:none; background:transparent; border:0; cursor:pointer; font-family:var(--mono); font-size:11px;
  letter-spacing:.04em; padding:8px 12px; min-width:40px; color:var(--soft); transition:color .25s}
.lang button.on{background:var(--ink); color:var(--ground)}
.lang button:hover:not(.on){color:var(--ink)}
.ig{font-family:var(--mono); font-size:10px; letter-spacing:.12em; color:var(--soft); transition:color .25s}
.ig:hover{color:var(--ink)}
.ig.mail{margin-top:-10px; text-transform:none; letter-spacing:.04em}
.passes{font-family:var(--serif); font-style:italic; font-size:12px; color:var(--soft); line-height:1.4}

/* ---------------- STAGE ---------------- */
.stage{flex:1 1 auto; min-width:0; padding:56px var(--pad) 120px; max-width:1440px}
body[data-route="home"] .stage{max-width:none}
.view{opacity:0; transition:opacity .4s ease}
.view.in{opacity:1}

/* shared masthead */
.masthead.has-photo{display:grid; grid-template-columns:1.12fr .88fr; gap:clamp(24px,4vw,56px); align-items:end}
.mh-photo{width:100%; max-height:440px; object-fit:cover; border-radius:2px; filter:saturate(.97) contrast(1.02);
  box-shadow:0 26px 54px -36px rgba(20,16,10,.55)}
body.dark .mh-photo{box-shadow:0 30px 64px -34px rgba(0,0,0,.75)}
.eyebrow{font-family:var(--mono); font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--soft); margin:0 0 16px}
.eyebrow .dot{color:var(--accent); transition:color .7s}
h1.display{font-family:var(--serif); font-weight:400; font-size:clamp(34px,6vw,68px); line-height:1.02; letter-spacing:-.015em; margin:0}
h1.display em{font-style:italic}
.body-line{font-family:var(--serif); font-style:italic; font-size:clamp(15px,2vw,19px); color:var(--soft); margin:14px 0 0; max-width:46ch}
.excerpt{font-family:var(--serif); font-size:clamp(16px,2.2vw,21px); line-height:1.5; max-width:54ch; margin:26px 0 0}
.excerpt em,.excerpt i{font-style:italic; color:var(--accent); transition:color .7s}
.medium{font-family:var(--mono); font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--soft); margin:18px 0 0}

/* ---------------- HOME ---------------- */
.home-hero{position:relative; margin:0}
.home-hero .photo{display:block; width:calc(100% + var(--pad) * 2); margin-inline:calc(-1*var(--pad)); height:clamp(380px,64vh,760px); object-fit:cover; filter:saturate(.97) contrast(1.02)}
.home-hero .quote{
  font-family:var(--serif); font-weight:400; font-size:clamp(26px,3.6vw,44px); line-height:1.16; letter-spacing:-.01em;
  max-width:32ch; margin:clamp(30px,3.6vw,46px) auto 14px; text-align:center}
.home-hero .quote em{font-style:italic; color:var(--accent); transition:color .7s}
.home-sub{font-family:var(--mono); font-size:12px; letter-spacing:.04em; color:var(--soft); line-height:1.9; max-width:60ch; margin-inline:auto; text-align:center}
.home-sub i{font-style:italic; font-family:var(--serif); font-size:13.5px}

/* home — big splashy category bands, title overlaid on the atmosphere photo */
.cats{margin:clamp(40px,6vw,80px) 0 0; margin-inline:calc(-1*var(--pad)); display:flex; flex-direction:column; gap:clamp(8px,1.6vw,18px)}
.cat{position:relative; display:block}
.cat-media{position:relative; overflow:hidden}
.cat-media img{width:100%; height:clamp(330px,56vh,660px); object-fit:cover; filter:saturate(.98) contrast(1.02);
  transition:transform 1.3s cubic-bezier(.2,.7,.2,1)}
.cat:hover .cat-media img{transform:scale(1.05)}
.cat-media::after{content:""; position:absolute; inset:0; pointer-events:none;
  background:linear-gradient(to top, rgba(18,14,9,.74), rgba(18,14,9,.18) 42%, rgba(18,14,9,0) 72%)}
.cat-overlay{position:absolute; left:0; bottom:0; z-index:2; padding:clamp(22px,4vw,52px) var(--pad); color:#f4ece0; max-width:88%}
.cat:nth-child(even) .cat-overlay{left:auto; right:0; text-align:right}
.cat-overlay .num{font-family:var(--mono); font-size:11px; letter-spacing:.1em; color:rgba(244,236,224,.72)}
.cat-title{font-family:var(--serif); font-weight:400; font-size:clamp(30px,5vw,60px); line-height:1.02; letter-spacing:-.015em; margin:8px 0 8px; color:#fff}
.cat-overlay .meta-t{display:block; font-family:var(--mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:rgba(244,236,224,.74)}
.cat-cta{display:inline-block; margin-top:16px; font-family:var(--mono); font-size:10.5px; letter-spacing:.16em; text-transform:uppercase;
  color:#f4ece0; border-bottom:1px solid rgba(244,236,224,.5); padding-bottom:3px; transition:border-color .3s}
.cat:hover .cat-cta{border-color:#f4ece0}

/* scroll reveal (IntersectionObserver adds .in) + parallax (.px transformed by JS) */
.reveal{opacity:0; transform:translateY(28px); transition:opacity 1s cubic-bezier(.2,.7,.2,1), transform 1s cubic-bezier(.2,.7,.2,1)}
.reveal.slide-l{transform:translateX(-52px)}
.reveal.slide-r{transform:translateX(52px)}
.reveal.in{opacity:1; transform:none}

/* matted plate — artwork shown COMPLETE (contain) on a neutral mat; robust to any framing.
   Mats sit near the ground colour, so margins read as quiet negative space, not a heavy frame. */
.plate{background:var(--mat); border-radius:2px; padding:clamp(12px,2.2vw,30px); display:flex; align-items:center; justify-content:center; transition:background-color .7s ease}
.plate img,.plate .work-img{width:auto; height:auto; max-width:100%; max-height:78vh; object-fit:contain; display:block; border-radius:1px;
  box-shadow:0 18px 42px -26px rgba(20,16,10,.5); transition:opacity .4s}
.plate:hover img{opacity:.95}
body.dark .plate img{box-shadow:0 26px 56px -28px rgba(0,0,0,.7)}

/* ---------------- COLLECTION — editorial alternating rows ---------------- */
.col-editorial{margin:clamp(44px,7vw,90px) 0 0}
.cwork{display:grid; grid-template-columns:1.12fr .88fr; gap:clamp(24px,4vw,60px); align-items:center; color:inherit;
  margin:0 0 clamp(56px,9vw,120px)}
.cwork.flip{grid-template-columns:.88fr 1.12fr}
.cwork.flip .cw-media{order:2}
.cwork.flip .cw-cap{text-align:right}
.cw-media .plate{width:100%}
.cw-cap .wt{font-family:var(--serif); font-weight:400; font-size:clamp(22px,3vw,34px); line-height:1.08; margin:0 0 12px}
.cw-cap .wy{font-family:var(--mono); font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--soft); display:block; margin-bottom:6px}
.cw-cap .wm{font-family:var(--mono); font-size:10.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--soft); display:block}

/* full-width atmosphere band woven into the scroll (parallax) */
.cband{margin:clamp(18px,3vw,48px) calc(-1*var(--pad)) clamp(56px,9vw,110px); overflow:hidden; max-height:72vh}
.cband img{width:100%; height:clamp(320px,60vh,640px); object-fit:cover; display:block}

/* Fragments grid — small matted indigo miniatures */
.col-grid{margin:clamp(40px,6vw,80px) 0 0; display:grid; grid-template-columns:repeat(auto-fill,minmax(190px,1fr)); gap:34px 26px}
.gcard{display:block; color:inherit}
.gcard .plate{padding:clamp(10px,1.6vw,20px)}
.gcard:nth-child(3n) .plate{transform:rotate(.5deg)}
.gcard:nth-child(4n) .plate{transform:rotate(-.6deg)}
.gcard .cap{margin:10px 2px 0}
.gcard .cap .wt{font-family:var(--mono); font-size:9.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--soft)}

.soon-block{margin:46px 0 0; padding:34px 0 0; border-top:1px solid var(--line)}
.soon-tag{display:inline-block; font-family:var(--mono); font-size:10px; letter-spacing:.2em; text-transform:uppercase;
  color:var(--accent); border:1px solid var(--accent); border-radius:30px; padding:7px 16px}

/* dark skin — let the matted works glow on the charcoal ground */
body.dark .home-hero .photo{filter:saturate(1) contrast(1.04) brightness(1.02)}

/* ---------------- BIO ---------------- */
.bio-wrap{display:grid; grid-template-columns:0.85fr 1.15fr; gap:clamp(30px,5vw,64px); align-items:start}
.bio-portrait{width:100%; border-radius:2px; box-shadow:0 30px 60px -42px rgba(20,16,10,.55)}
.bio-body h1{margin-bottom:22px}
.bio-manifesto{font-family:var(--serif); font-size:clamp(16px,2.1vw,20px); line-height:1.55; margin:0 0 22px}
.bio-manifesto i{font-style:italic; color:var(--accent)}
.bio-facts{font-family:var(--mono); font-size:11px; letter-spacing:.04em; color:var(--soft); line-height:1.9}
.bio-atelier{width:100%; margin-top:30px; border-radius:2px; opacity:.95}
.read-full{display:inline-block; margin:10px 0 26px; font-family:var(--mono); font-size:10px; letter-spacing:.16em;
  text-transform:uppercase; color:var(--accent); border-bottom:1px solid var(--accent); padding-bottom:3px; transition:color .25s, border-color .25s}
.read-full:hover{color:var(--ink); border-color:var(--ink)}

/* ---------------- ABOUT (excerpt → portrait+bio+contact → events) ---------------- */
.about-excerpt{max-width:64ch; margin:6px 0 clamp(46px,7vw,86px)}
.about-quote{font-family:var(--serif); font-size:clamp(20px,2.8vw,30px); line-height:1.42; margin:18px 0 0;
  padding-left:clamp(18px,3.4vw,48px); border-left:2px solid var(--accent)}
.about-quote em,.about-quote i{font-style:italic; color:var(--accent); transition:color .7s}
.about-coda{font-family:var(--serif); font-style:italic; color:var(--soft); margin:22px 0 0; font-size:15px; padding-left:clamp(18px,3.4vw,48px)}
.about-bio{display:grid; grid-template-columns:.95fr 1.05fr; gap:clamp(28px,5vw,60px); align-items:start;
  padding:0 0 clamp(46px,7vw,78px); border-bottom:1px solid var(--line)}
.about-portrait{width:100%; border-radius:2px; box-shadow:0 30px 60px -42px rgba(20,16,10,.5)}
.about-text h1.display{font-size:clamp(26px,3.4vw,40px); margin:0 0 18px}
.bio-text{font-family:var(--serif); font-size:clamp(15px,1.9vw,18px); line-height:1.6; margin:0 0 30px; max-width:46ch}
.about-h{font-family:var(--mono); font-size:10px; letter-spacing:.22em; text-transform:uppercase; color:var(--soft); font-weight:400; margin:0 0 12px}
.contact-line{font-family:var(--serif); font-size:16px; margin:0 0 7px}
.contact-ig{font-family:var(--mono); font-size:11px; letter-spacing:.08em; color:var(--accent); border-bottom:1px solid var(--accent); padding-bottom:2px; transition:color .25s, border-color .25s}
.contact-handles{display:inline-flex; align-items:center; gap:10px; white-space:nowrap}
.contact-handles .sep{color:var(--soft); font-family:var(--mono); font-size:11px}
.contact-mail:hover,.contact-ig:hover{color:var(--ink); border-color:var(--ink)}
.about-events{padding:clamp(40px,6vw,64px) 0 0}
.events{list-style:none; margin:0; padding:0; max-width:66ch}
.events li{display:grid; grid-template-columns:60px 1fr auto; gap:8px 22px; align-items:baseline; padding:16px 0; border-bottom:1px solid var(--line)}
.ev-year{font-family:var(--mono); font-size:12px; color:var(--accent)}
.ev-title{font-family:var(--serif); font-size:17px}
.ev-venue{font-family:var(--mono); font-size:10.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--soft); text-align:right}
@media(max-width:760px){
  .about-bio{grid-template-columns:1fr}
  .events li{grid-template-columns:46px 1fr}
  .ev-venue{grid-column:2; text-align:left; margin-top:2px}
}

/* ---------------- COMMISSIONS ---------------- */
.commissions{max-width:64ch; margin-top:clamp(30px,5vw,52px)}
.steps{list-style:none; margin:0 0 30px; padding:0}
.steps li{display:grid; grid-template-columns:40px 1fr; gap:16px; align-items:baseline; padding:15px 0; border-bottom:1px solid var(--line)}
.steps .stp-n{font-family:var(--mono); font-size:12px; color:var(--accent)}
.steps .stp-t{font-family:var(--serif); font-size:clamp(16px,2vw,20px); line-height:1.4}
.comm-price{font-family:var(--mono); font-size:11px; letter-spacing:.05em; text-transform:uppercase; color:var(--soft); line-height:1.7; margin:0 0 28px}

/* contact block (About) */
.contact-block{margin-top:6px}
.contact-links{display:flex; flex-wrap:wrap; align-items:center; gap:14px 18px; margin-top:14px}
.contact-mail{font-family:var(--mono); font-size:11px; letter-spacing:.04em; color:var(--accent); border-bottom:1px solid var(--accent); padding-bottom:2px; transition:color .25s, border-color .25s}
.manifesto-full{font-family:var(--serif); font-size:clamp(15px,1.8vw,18px); line-height:1.62; color:var(--soft); margin:18px 0 6px; max-width:62ch; padding-left:clamp(18px,3.4vw,48px)}
.about-excerpt .read-full{margin:6px 0 0; margin-left:clamp(18px,3.4vw,48px)}

/* ---------------- SHOP ---------------- */
.shop-intro{font-family:var(--serif); font-style:italic; color:var(--soft); font-size:16px; margin:14px 0 40px; max-width:50ch}
.shop-sec{font-family:var(--serif); font-weight:400; font-size:clamp(20px,2.6vw,28px); letter-spacing:-.01em;
  margin:clamp(36px,5vw,58px) 0 20px; padding-bottom:11px; border-bottom:1px solid var(--line)}
.shop-grid{display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:clamp(22px,3vw,44px)}
.card{display:block}
.card .wrap-img{overflow:hidden; border-radius:2px; background:var(--mat); aspect-ratio:1/1;
  display:flex; align-items:center; justify-content:center; padding:clamp(12px,2vw,24px); transition:background-color .7s}
.card img{width:auto; height:auto; max-width:100%; max-height:100%; object-fit:contain;
  box-shadow:0 12px 26px -18px rgba(20,16,10,.45); transition:transform .9s cubic-bezier(.2,.7,.2,1)}
.card:hover img{transform:scale(1.035)}
.card .ct{font-family:var(--serif); font-size:15px; margin:11px 2px 2px}
.card .cp{font-family:var(--mono); font-size:9.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--soft); margin:0 2px}

/* work detail */
.detail{display:grid; grid-template-columns:1.25fr .75fr; gap:clamp(28px,5vw,60px); align-items:start}
.detail .plate.big{width:100%; padding:clamp(14px,2.5vw,38px)}
.detail .plate.big img{max-height:82vh}
.detail h1{font-size:clamp(26px,4vw,40px); margin:4px 0 4px}
.detail .d-year{font-family:var(--serif); font-style:italic; color:var(--soft); margin:0 0 22px}
.detail dl{font-family:var(--mono); font-size:11px; line-height:2; color:var(--ink); border-top:1px solid var(--line); border-bottom:1px solid var(--line); padding:14px 0; margin:0 0 20px}
.detail dt{display:inline-block; width:120px; color:var(--soft); font-size:9.5px; letter-spacing:.1em; text-transform:uppercase}
.detail .price{font-family:var(--serif); font-size:23px; margin:0 0 18px}
.btn{display:inline-block; cursor:pointer; background:var(--accent); color:#fff; font-family:var(--mono); font-size:10px;
  letter-spacing:.2em; text-transform:uppercase; padding:14px 30px; border-radius:1px; border:0; transition:opacity .3s}
.btn:hover{opacity:.85}
.ship{font-family:var(--mono); font-size:9.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--soft); margin:13px 0 0}
.sold-tag{display:inline-block; font-family:var(--mono); font-size:10px; letter-spacing:.2em; text-transform:uppercase;
  color:var(--soft); border:1px solid var(--line); border-radius:30px; padding:11px 22px}
.backlink{font-family:var(--mono); font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--soft); margin:0 0 30px; display:inline-block}

/* ---------------- responsive ---------------- */
@media(max-width:900px){
  #app{flex-direction:column}
  .spine{width:auto; flex:none; position:sticky; top:0; height:auto; z-index:20;
    flex-direction:row; flex-wrap:wrap; align-items:center; gap:12px 20px; padding:13px var(--pad);
    border-right:0; border-bottom:1px solid var(--line); background:var(--ground)}
  .brand{font-size:17px} .brand small{display:none}
  .idx{flex-direction:row; flex-wrap:wrap; gap:6px 16px; order:3; width:100%}
  .idx-h{display:none}
  .idx li a{grid-template-columns:auto auto; gap:7px; padding:5px 0; border-bottom:0}
  .idx .cn{font-size:15px} .idx .ct{display:none}
  .spine-nav{flex-direction:row; gap:16px; margin-left:auto; font-size:11px}
  .spine-foot{margin:0; flex-direction:row; align-items:center; gap:12px}
  .passes,.ig{display:none}
  .stage{padding:30px var(--pad) 90px}
  .about-bio,.detail{grid-template-columns:1fr; gap:24px}
  .cwork,.cwork.flip{grid-template-columns:1fr; gap:16px}
  .cwork.flip .cw-media{order:0}
  .cwork.flip .cw-cap{text-align:left}
  .reveal.slide-l,.reveal.slide-r{transform:translateY(28px)}
  .cband img{height:clamp(220px,40vh,360px)}
  .col-grid{grid-template-columns:1fr 1fr; gap:20px 16px}
  .cat-media img{height:clamp(260px,46vh,420px)}
  .cat-overlay{padding:20px var(--pad)}
}
@media(prefers-reduced-motion:reduce){
  *{transition:none!important}
  .reveal{opacity:1!important; transform:none!important}
  .px{transform:none!important}
}
