:root{
  --bg:#f6f4ef;
  --bg-2:#ebe7dc;
  --surface:#ffffff;
  --ink:#1a1a1a;
  --ink-2:#2a2a2a;
  --muted:#6b6b66;
  --line:#d9d5cc;
  --accent:#a0391f;
  --gold:#b08a3e;
  --max:1280px;
  --shadow-lg:0 40px 80px -30px rgba(0,0,0,.35);
  --shadow-md:0 20px 40px -20px rgba(0,0,0,.15);
  --tile-bg:#ebe7dc;
  --input-bg:#fff;
  --overlay-grad:linear-gradient(to top, rgba(20,15,10,.85) 0%, rgba(20,15,10,.35) 45%, transparent 75%);
}
[data-theme="dark"]{
  --bg:#111110;
  --bg-2:#1b1b1a;
  --surface:#1c1c1b;
  --ink:#ede9e0;
  --ink-2:#d8d3c6;
  --muted:#a19d92;
  --line:#2e2d2a;
  --accent:#e8826a;
  --gold:#d5ad5f;
  --tile-bg:#1b1b1a;
  --input-bg:#1a1a19;
  --shadow-lg:0 40px 80px -30px rgba(0,0,0,.7);
  --shadow-md:0 20px 40px -20px rgba(0,0,0,.5);
  --overlay-grad:linear-gradient(to top, rgba(5,5,3,.92) 0%, rgba(5,5,3,.45) 45%, transparent 75%);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);color:var(--ink);
  font-family:'Inter',system-ui,sans-serif;font-weight:300;line-height:1.55;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
  transition:background .25s ease, color .25s ease;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:'Cormorant Garamond',serif;font-weight:400;letter-spacing:-.01em;line-height:1.05;color:var(--ink)}
h1{font-size:clamp(3rem,8vw,7rem)}
h2{font-size:clamp(2rem,4vw,3.4rem)}
h3{font-size:clamp(1.6rem,3vw,2.4rem)}
em{font-style:italic;color:var(--accent)}

.eyebrow{font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);margin-bottom:1rem}
.lede{color:var(--muted);max-width:46ch;font-size:1.05rem;margin-top:1.5rem}

/* NAV */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;justify-content:space-between;align-items:center;
  padding:1.2rem clamp(1.2rem,4vw,3rem);
  backdrop-filter:blur(10px);background:rgba(246,244,239,.75);
  border-bottom:1px solid var(--line);
  transition:background .25s;
}
[data-theme="dark"] .nav{background:rgba(17,17,16,.75)}
.brand{font-family:'Cormorant Garamond',serif;font-size:1.3rem;color:var(--ink)}
.nav nav{display:flex;gap:1.4rem;align-items:center}
.nav nav a{font-size:.85rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);transition:color .2s}
.nav nav a:hover{color:var(--ink)}
.nav-ctrl{display:flex;gap:.4rem;align-items:center;margin-left:1rem}

.pill{
  padding:.35rem .8rem;border:1px solid var(--line);background:transparent;color:var(--ink);
  font-family:inherit;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;
  cursor:pointer;transition:all .15s;border-radius:999px;
  display:inline-flex;align-items:center;gap:.3rem;
}
.pill:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}
#theme-toggle .i-moon{display:none}
#theme-toggle .i-sun{display:inline}
[data-theme="dark"] #theme-toggle .i-sun{display:none}
[data-theme="dark"] #theme-toggle .i-moon{display:inline}

/* HERO */
.hero{
  min-height:100vh;display:grid;grid-template-columns:1.1fr 1fr;
  gap:clamp(2rem,6vw,6rem);align-items:center;
  padding:9rem clamp(1.2rem,4vw,3rem) 4rem;max-width:var(--max);margin:0 auto;
}
.hero-text h1{margin:1.2rem 0 0}
.hero-img img{width:100%;aspect-ratio:4/5;object-fit:cover;box-shadow:var(--shadow-lg)}

.cta{
  display:inline-block;margin-top:2rem;padding:.9rem 1.6rem;border:1px solid var(--ink);
  font-size:.8rem;letter-spacing:.2em;text-transform:uppercase;transition:all .25s ease;cursor:pointer;background:transparent;color:var(--ink);
  font-family:inherit;
}
.cta:hover{background:var(--ink);color:var(--bg)}

/* WORKS */
.works{padding:6rem clamp(1.2rem,4vw,3rem);max-width:var(--max);margin:0 auto;border-top:1px solid var(--line)}
.works-intro{text-align:center;margin-bottom:3rem;font-size:.75rem;letter-spacing:.3em}
.section-head{text-align:center;max-width:680px;margin:0 auto 4rem}
.section-head .lede{margin-left:auto;margin-right:auto}

.collection{margin-bottom:5rem}
.collection:last-of-type{margin-bottom:0}
.collection-head{text-align:center;max-width:none;margin:0 0 2.4rem;display:block}
.collection-head h3{font-size:clamp(1.4rem,2.4vw,2rem);margin:0;letter-spacing:-.01em;color:var(--ink);display:flex;align-items:center;justify-content:center;gap:1.2rem;white-space:nowrap}
.collection-head h3::before,.collection-head h3::after{content:'';flex:1;max-width:120px;height:1px;background:var(--line)}
.collection-head .collection-desc{color:var(--muted);font-size:.85rem;line-height:1.65;margin:.8rem auto 0;max-width:56ch}
@media(max-width:600px){.collection-head h3{white-space:normal}.collection-head h3::before,.collection-head h3::after{max-width:40px}}
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:1.4rem;grid-auto-flow:dense}
/* Collections : flex-wrap centré pour quelques tuiles seulement */
.collection-grid{display:flex;flex-wrap:wrap;gap:1.4rem;justify-content:center;grid-template-columns:none;grid-auto-flow:initial}
.collection-grid .tile{grid-column:auto;flex:0 0 calc((100% - 2 * 1.4rem) / 3);aspect-ratio:3/4}
.collection-grid .tile.wide{flex-basis:calc((100% - 1.4rem) * 2 / 3);aspect-ratio:16/10}
.collection-grid .tile.square{flex-basis:calc((100% - 2 * 1.4rem) / 3);aspect-ratio:1/1}
.collection-grid .tile.tall{flex-basis:calc((100% - 2 * 1.4rem) / 3);aspect-ratio:3/4}
/* Tile sizes — override flex-basis */
.collection-grid .tile[data-size="small"]{flex-basis:calc((100% - 4.2rem) / 4)}
.collection-grid .tile[data-size="large"]{flex-basis:calc((100% - 1.4rem) / 2)}
.collection-grid .tile.wide[data-size="small"]{flex-basis:calc((100% - 4.2rem) * 2 / 4)}
.collection-grid .tile.wide[data-size="large"]{flex-basis:100%}
@media(max-width:900px){
  .collection-grid .tile,.collection-grid .tile.tall,.collection-grid .tile.square{flex-basis:calc((100% - 1.4rem) / 2)}
  .collection-grid .tile.wide{flex-basis:100%}
}
@media(max-width:560px){
  .collection-grid .tile,.collection-grid .tile.tall,.collection-grid .tile.wide,.collection-grid .tile.square{flex-basis:100%;aspect-ratio:4/5}
}
.tile-empty{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:var(--muted);font-family:'Cormorant Garamond',serif;font-size:3rem;background:var(--tile-bg)}
.tile{grid-column:span 4;position:relative;overflow:hidden;cursor:pointer;background:var(--tile-bg);aspect-ratio:3/4}
.tile.tall{grid-column:span 4;aspect-ratio:3/4}
.tile.wide{grid-column:span 8;aspect-ratio:16/10}
.tile.square{grid-column:span 4;aspect-ratio:1/1}
.tile > img{width:100%;height:100%;object-fit:cover;object-position:center;transition:transform .8s cubic-bezier(.2,.7,.2,1),filter .4s}
.tile[data-fit="contain"] > img{object-fit:contain;padding:.6rem;background:var(--tile-bg)}
.tile[data-position="top"] > img{object-position:center top}
.tile[data-position="bottom"] > img{object-position:center bottom}
.tile[data-position="left"] > img{object-position:left center}
.tile[data-position="right"] > img{object-position:right center}
.tile:hover > img{transform:scale(1.04);filter:brightness(.85)}

.tile .overlay{
  position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;
  padding:1.6rem;color:#fff;background:var(--overlay-grad);
  opacity:0;transform:translateY(10px);transition:opacity .35s, transform .35s;pointer-events:none;
}
.tile:hover .overlay{opacity:1;transform:none}
.tile .overlay .t-title{font-family:'Cormorant Garamond',serif;font-size:1.6rem;line-height:1.1;margin-bottom:.4rem}
.tile .overlay .t-meta{font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.75);margin-bottom:.8rem}
.tile .overlay .t-desc{font-size:.9rem;color:rgba(255,255,255,.9);margin-bottom:1rem;max-width:42ch;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.tile .overlay .t-price-row{display:flex;align-items:center;gap:.8rem;flex-wrap:wrap}
.tile .overlay .t-price{font-size:1rem;letter-spacing:.04em}

.blurred{filter:blur(5px);user-select:none;transition:filter .25s ease;cursor:help}
.lb-price .blurred{filter:blur(6px)}

.badge{display:inline-block;padding:.22rem .55rem;font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;border:1px solid currentColor;border-radius:2px}
.badge.available{color:#5a7a3a;border-color:#5a7a3a}
.badge.sold{color:#a13a2b;border-color:#a13a2b}
.badge.reserved{color:var(--gold);border-color:var(--gold)}
.badge.archive{color:var(--muted);border-color:var(--muted)}
[data-theme="dark"] .badge.available{color:#9cc076;border-color:#9cc076}
[data-theme="dark"] .badge.sold{color:#e8826a;border-color:#e8826a}

.tile .overlay .badge{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.5)}
.tile .overlay .badge.sold{color:#ffb6a6;border-color:#ffb6a6}
.tile .overlay .badge.reserved{color:#f3d9a8;border-color:#f3d9a8}
.tile .overlay .badge.available{color:#bfe0a1;border-color:#bfe0a1}

.tile .caption{display:none;padding:.9rem 0 0}
.tile .caption .c-title{font-family:'Cormorant Garamond',serif;font-size:1.15rem;line-height:1.15;color:var(--ink)}
.tile .caption .c-meta{font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-top:.2rem}
.tile .caption .c-price-row{display:flex;justify-content:space-between;align-items:center;margin-top:.5rem;font-size:.95rem}

.multi-badge{position:absolute;top:.8rem;right:.8rem;z-index:2;background:rgba(0,0,0,.55);color:#fff;padding:.3rem .55rem;font-size:.7rem;letter-spacing:.1em;border-radius:3px;backdrop-filter:blur(6px);pointer-events:none}

@media(max-width:900px){
  .hero{display:flex;flex-direction:column;padding-top:7rem;gap:1.2rem}
  .hero-text{display:contents}
  .hero .eyebrow{order:0}
  .hero h1{order:1;margin:.4rem 0 .4rem}
  .hero-img{order:2;margin:.6rem 0}
  .hero-img img{aspect-ratio:auto;width:auto;max-width:100%;height:auto;margin:0 auto;object-fit:contain}
  .hero .lede{order:3;margin-top:0}
  .hero .cta{order:4;align-self:flex-start}
  .tile,.tile.tall,.tile.square{grid-column:span 6}
  .tile.wide{grid-column:span 12}
  .nav nav{gap:.8rem}
  .nav-ctrl{margin-left:.4rem}
}
@media(max-width:560px){
  .tile, .tile.tall, .tile.wide, .tile.square,
  .collection-grid .tile, .collection-grid .tile.tall, .collection-grid .tile.wide, .collection-grid .tile.square{
    grid-column:span 12; flex-basis:100%;
    aspect-ratio:auto; display:block;
    background:transparent; overflow:visible;
  }
  .tile .overlay{display:none}
  .tile > img{
    width:100%; height:auto;
    object-fit:contain; aspect-ratio:auto;
    background:transparent; padding:0 !important;
  }
  .tile .caption{display:block; padding:.9rem 0 0}
  .tile .c-info-row{display:flex; justify-content:space-between; align-items:baseline; gap:.8rem; margin-bottom:.5rem}
  .tile .c-title{font-family:'Cormorant Garamond',serif; font-size:1.25rem; line-height:1.15; color:var(--ink); margin:0}
  .tile .c-dim{font-size:.78rem; letter-spacing:.06em; color:var(--muted); white-space:nowrap}
  .tile .c-meta{display:none}
  .tile .c-price-row{display:flex; justify-content:space-between; align-items:center; font-size:.98rem; color:var(--ink)}
  .tile[data-fit="contain"] > img{background:transparent}
  .tile:hover > img{transform:none; filter:none}
  .tile .multi-badge{top:.6rem; right:.6rem; bottom:auto}
  .nav nav a:not(.pill){display:none}
}
@media(hover:none) and (min-width:561px){
  .tile .overlay{display:none}
  .tile .caption{display:block}
  .tile:hover > img{transform:none; filter:none}
}

/* ABOUT */
.about{
  display:grid;grid-template-columns:1fr 1.2fr;gap:clamp(2rem,6vw,6rem);align-items:center;
  padding:6rem clamp(1.2rem,4vw,3rem);max-width:var(--max);margin:0 auto;border-top:1px solid var(--line);
}
.about-img img{aspect-ratio:3/4;object-fit:cover;filter:grayscale(.1);box-shadow:var(--shadow-md)}
.about-text p{margin-top:1.2rem;max-width:50ch;color:var(--ink-2)}
.about-text .meta{color:var(--muted);font-size:.85rem;letter-spacing:.08em;margin-top:2rem;text-transform:uppercase}
@media(max-width:900px){.about{grid-template-columns:1fr}.about-img img{max-width:360px;margin:0 auto}}

.contact{padding:8rem clamp(1.2rem,4vw,3rem);max-width:var(--max);margin:0 auto;border-top:1px solid var(--line)}
.contact .section-head{margin-bottom:0}

/* FOOTER */
footer{padding:2.4rem clamp(1.2rem,4vw,3rem);border-top:1px solid var(--line);color:var(--muted);font-size:.82rem;letter-spacing:.04em;display:flex;flex-direction:column;gap:1.6rem}
.foot-row{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.foot-links{display:flex;gap:1.4rem}
.foot-links a:hover,.foot-row a:hover{color:var(--ink)}
.socials{display:flex;gap:1.2rem;flex-wrap:wrap}
.socials a{display:inline-flex;align-items:center;gap:.5rem;color:var(--muted);transition:color .2s}
.socials a:hover{color:var(--ink)}
.socials svg{flex-shrink:0}
.footer-meta a{text-decoration:underline}

/* LIGHTBOX */
.lightbox{position:fixed;inset:0;z-index:100;background:rgba(20,18,14,.96);display:none;align-items:center;justify-content:center;padding:2rem}
[data-theme="light"] .lightbox{background:rgba(20,18,14,.96)}
.lightbox.open{display:flex}
.lb-inner{display:grid;grid-template-columns:1.3fr 1fr;gap:2.4rem;max-width:1280px;width:100%;max-height:90vh}
.lb-gallery{display:flex;flex-direction:column;gap:1rem;min-width:0}
.lb-img{position:relative;display:flex;align-items:center;justify-content:center;min-height:0}
.lb-img img{max-width:100%;max-height:76vh;object-fit:contain;box-shadow:0 40px 100px rgba(0,0,0,.6);user-select:none;-webkit-user-drag:none}
.lb-prev,.lb-next{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.3);color:#fff;font-size:1.6rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;backdrop-filter:blur(8px)}
.lb-prev{left:-20px}
.lb-next{right:-20px}
.lb-prev:hover,.lb-next:hover{background:rgba(255,255,255,.18);border-color:#fff}
.lb-count{position:absolute;bottom:.8rem;left:50%;transform:translateX(-50%);color:#fff;font-size:.75rem;letter-spacing:.15em;background:rgba(0,0,0,.5);padding:.3rem .8rem;border-radius:12px;backdrop-filter:blur(8px)}
.lb-thumbs{display:flex;gap:.5rem;overflow-x:auto;padding:.2rem 0 .4rem;scrollbar-width:thin}
.lb-thumbs:empty{display:none}
.lb-thumbs button{flex:0 0 70px;height:70px;padding:0;border:1px solid rgba(255,255,255,.2);background:transparent;cursor:pointer;overflow:hidden;opacity:.55;transition:all .2s}
.lb-thumbs button:hover{opacity:.85}
.lb-thumbs button.active{opacity:1;border-color:#fff}
.lb-thumbs button img{width:100%;height:100%;object-fit:cover}

.lb-meta{color:#eee;padding:1rem;align-self:center}
.lb-meta h3{color:#fff;margin:.6rem 0 .8rem}
.lb-meta .lb-sub{color:#bfb9a8;font-size:.9rem;margin-top:.2rem}
.lb-meta .lb-desc{margin:1.4rem 0;color:#d6d0bf;line-height:1.65;font-size:.96rem;max-width:46ch}
.lb-meta .lb-price{margin-top:1.4rem;display:flex;align-items:center;gap:.8rem;font-size:1.2rem;font-family:'Cormorant Garamond',serif}
.lb-meta .lb-price:empty{display:none}
.lb-variants{list-style:none;padding:0;margin:.8rem 0 0;border-top:1px solid rgba(255,255,255,.1);padding-top:.8rem}
.lb-variants:empty{display:none;border:0;padding:0;margin:0}
.lb-variants li{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;padding:.4rem 0;font-size:.92rem;color:#d6d0bf;border-bottom:1px solid rgba(255,255,255,.06)}
.lb-variants li:last-child{border-bottom:0}
.lb-variants .pv-label{flex:1;color:#bfb9a8}
.lb-variants .pv-price{font-family:'Cormorant Garamond',serif;font-size:1.1rem;color:#fff;letter-spacing:.02em}
.lb-edition{margin-top:1rem;font-size:.78rem;letter-spacing:.04em;color:#8d8675;font-style:italic}
.lb-edition:empty{display:none}
.lb-meta .eyebrow{color:#8d8675}
.lb-actions{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap;margin-top:1.6rem}
.lb-contact{margin-top:0;border-color:rgba(255,255,255,.7);color:#fff;background:transparent}
.lb-contact:hover{background:#fff;color:#1a1a1a;border-color:#fff}
.lb-share{border-color:rgba(255,255,255,.4);color:#fff}
.lb-share:hover{background:rgba(255,255,255,.15)}
.lb-close{position:absolute;top:1.2rem;right:1.6rem;width:44px;height:44px;border-radius:50%;background:transparent;border:1px solid rgba(255,255,255,.4);color:#fff;font-size:1.6rem;line-height:1;cursor:pointer;transition:all .2s}
.lb-close:hover{background:rgba(255,255,255,.15);border-color:#fff}
@media(max-width:800px){.lb-inner{grid-template-columns:1fr;gap:1rem;overflow-y:auto}.lb-img img{max-height:50vh}.lb-prev{left:.4rem}.lb-next{right:.4rem}.lb-thumbs button{flex:0 0 56px;height:56px}}

/* MODAL */
.modal{position:fixed;inset:0;z-index:100;background:rgba(20,18,14,.55);display:none;align-items:center;justify-content:center;padding:2rem;backdrop-filter:blur(6px)}
.modal.open{display:flex;animation:modal-in .25s ease}
@keyframes modal-in{from{opacity:0}to{opacity:1}}
.modal-inner{background:var(--bg);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;padding:clamp(1.6rem,3vw,2.4rem);position:relative;border:1px solid var(--line);box-shadow:0 60px 120px -40px rgba(0,0,0,.4)}
.modal-close{position:absolute;top:1rem;right:1.2rem;width:40px;height:40px;border-radius:50%;background:transparent;border:1px solid var(--line);color:var(--ink);font-size:1.4rem;line-height:1;cursor:pointer;transition:all .2s}
.modal-close:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.modal-inner h3{font-size:clamp(1.6rem,3vw,2.2rem);margin:.3rem 0 .8rem;font-family:'Cormorant Garamond',serif;font-weight:400}
.modal-lede{color:var(--muted);font-size:.92rem;margin-bottom:1.6rem}

.fld{margin-bottom:.9rem;display:flex;flex-direction:column}
.fld-row{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}
.fld label{font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);margin-bottom:.3rem}
.fld label span{color:var(--accent);margin-left:.15em}
.fld label span.either{color:var(--gold)}
.fld input,.fld textarea,.fld select{width:100%;padding:.7rem .8rem;border:1px solid var(--line);background:var(--input-bg);font-family:inherit;font-size:.94rem;font-weight:300;color:var(--ink);transition:border-color .15s}
.fld input:focus,.fld textarea:focus,.fld select:focus{outline:none;border-color:var(--ink)}
.fld textarea{resize:vertical}
.fld.invalid input,.fld.invalid textarea{border-color:var(--accent)}

.turnstile-box{margin:1rem 0;min-height:0}
.turnstile-box:empty{margin:0}

.form-actions{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-top:1.4rem}
.form-hint{font-size:.72rem;color:var(--muted);letter-spacing:.05em}
.either-note{color:var(--gold)}
.form-err{color:var(--accent);font-size:.88rem;margin-top:.6rem}
.form-ok{color:#5a7a3a;font-size:.92rem;margin-top:.6rem;padding:.7rem;background:#eef3e6;border:1px solid #c5d5a8}
[data-theme="dark"] .form-ok{background:#1f2b18;color:#9cc076;border-color:#334226}

@media(max-width:500px){.fld-row{grid-template-columns:1fr}.modal-inner{padding:1.4rem}}

/* TOAST */
.toast{position:fixed;bottom:2rem;left:50%;transform:translateX(-50%) translateY(20px);padding:.8rem 1.4rem;background:var(--ink);color:var(--bg);font-size:.85rem;letter-spacing:.05em;border-radius:3px;opacity:0;transition:all .25s;z-index:200;pointer-events:none;box-shadow:0 20px 40px rgba(0,0,0,.3)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* Edit mode (inside preview iframe) */
body.edit-mode .tile{cursor:crosshair;outline:1px dashed transparent;transition:outline-color .15s}
body.edit-mode .tile:hover{outline-color:rgba(160,57,31,.45)}
body.edit-mode .tile.editing{outline:2px solid var(--accent);outline-offset:3px}
body.edit-mode{padding-top:32px}
body.edit-mode::before{
  content:"Mode édition — cliquer une œuvre pour l'ajuster";
  position:fixed;top:0;left:0;right:0;z-index:90;
  background:var(--accent);color:#fff;text-align:center;padding:6px;
  font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;
}

#tile-toolbar{
  position:fixed;top:48px;right:16px;z-index:95;width:260px;max-height:calc(100vh - 70px);overflow-y:auto;
  background:#1a1a1a;color:#f6f4ef;border:1px solid #2e2d2a;
  border-radius:4px;padding:.8rem;box-shadow:0 30px 60px rgba(0,0,0,.4);
  font-family:'Inter',sans-serif;
}
@media(max-width:560px){#tile-toolbar{top:40px;right:8px;left:8px;width:auto}}
#tile-toolbar .tt-row{display:flex;flex-direction:column;gap:.3rem;margin-bottom:.8rem}
#tile-toolbar .tt-row:first-child{flex-direction:row;justify-content:space-between;align-items:center;border-bottom:1px solid #2e2d2a;padding-bottom:.5rem}
#tile-toolbar .tt-title{font-family:'Cormorant Garamond',serif;font-size:1rem;color:#fff}
#tile-toolbar .tt-close{background:transparent;border:1px solid #2e2d2a;color:#fff;width:24px;height:24px;font-size:1rem;line-height:1;cursor:pointer;border-radius:2px;padding:0}
#tile-toolbar .tt-close:hover{background:#a13a2b;border-color:#a13a2b}
#tile-toolbar label{font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:#a19d92;display:flex;justify-content:space-between}
#tile-toolbar label b{color:#fff;font-weight:500;letter-spacing:0;text-transform:none}
#tile-toolbar input[type=range]{width:100%;accent-color:var(--accent);cursor:pointer}
#tile-toolbar .tt-btns{display:flex;gap:.2rem;flex-wrap:wrap}
#tile-toolbar .tt-btns button{flex:1;padding:.3rem .4rem;font-size:.72rem;background:#2a2a28;border:1px solid #2e2d2a;color:#c9c3b2;border-radius:2px;cursor:pointer}
#tile-toolbar .tt-btns button:hover{background:#3a3a38;color:#fff}
#tile-toolbar .tt-btns button.on{background:var(--accent);color:#fff;border-color:var(--accent)}
#tile-toolbar .tt-btns-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:.2rem}

.reveal{opacity:0;transform:translateY(24px);transition:opacity .9s ease,transform .9s ease}
.reveal.in{opacity:1;transform:none}
