
:root{
 --bg:#f5f1e9; --bg2:#ece6d9; --ink:#1d1a16; --dim:#6f6a5f;
 --gold:#a3803f; --line:#d8d0bf;
 --dark:#15120e; --dark2:#1e1a15; --ink-on-dark:#ece6d9; --dim-on-dark:#96907f;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:'Jost',sans-serif;font-weight:300;letter-spacing:.02em;overflow-x:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--gold);color:#fff}
.gserif{font-family:'Cormorant Garamond',serif}

/* LOADER */
#loader{position:fixed;inset:0;background:var(--bg);z-index:200;display:flex;flex-direction:column;align-items:center;justify-content:center;transition:opacity .8s,visibility .8s}
#loader.off{opacity:0;visibility:hidden}
#loader .m{font-family:'Cormorant Garamond',serif;font-size:44px;font-style:italic;letter-spacing:.06em}
#loader .l{width:60px;height:1px;background:var(--gold);margin-top:18px;animation:lw 1.4s ease infinite alternate}
@keyframes lw{from{transform:scaleX(.3)}to{transform:scaleX(1)}}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;justify-content:space-between;align-items:center;padding:26px 54px;transition:all .45s}
nav.scrolled{background:rgba(245,241,233,.94);backdrop-filter:blur(10px);padding:14px 54px;border-bottom:1px solid var(--line)}
nav .logo{font-family:'Cormorant Garamond',serif;font-size:22px;letter-spacing:.14em;text-transform:uppercase}
nav .logo em{font-style:italic;color:var(--gold)}
nav ul{display:flex;gap:32px;list-style:none;align-items:center}
nav ul a{font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--dim);transition:color .3s;position:relative}
nav ul a::after{content:'';position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--gold);transition:width .35s}
nav ul a:hover::after,nav ul a.on::after{width:100%}
nav ul a:hover,nav ul a.on{color:var(--ink)}
nav.ondark:not(.scrolled) .logo,nav.ondark:not(.scrolled) ul a{color:var(--ink-on-dark)}
nav .lang{border:1px solid var(--line);padding:6px 13px}
nav .burger{display:none}

/* HERO SLIDESHOW */
.hero{position:relative;height:100vh;overflow:hidden;background:var(--dark)}
.hero .slide{position:absolute;inset:0;background-position:center;background-size:cover;opacity:0;transform:scale(1.08);transition:opacity 2.2s ease}
.hero .slide.on{opacity:1;animation:kb 9s ease forwards}
@keyframes kb{from{transform:scale(1.08)}to{transform:scale(1)}}
.hero::after{content:'';position:absolute;inset:0;background:linear-gradient(rgba(21,18,14,.25),rgba(21,18,14,.55))}
.hero .c{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:#f5f1e9;padding:0 24px}
.hero .k{font-size:11px;letter-spacing:.55em;text-transform:uppercase;color:#cdb37e;margin-bottom:30px}
.hero h1{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:clamp(52px,8.5vw,130px);line-height:.98;letter-spacing:.02em}
.hero h1 em{font-style:italic;font-weight:400}
.hero .sub{margin-top:30px;font-size:12px;letter-spacing:.4em;text-transform:uppercase;color:rgba(245,241,233,.75)}
.hero .rule{width:1px;height:70px;background:linear-gradient(var(--gold),transparent);margin-top:44px}
.hero .dots{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);z-index:3;display:flex;gap:12px}
.hero .dots i{width:26px;height:1px;background:rgba(245,241,233,.35);cursor:pointer;transition:background .3s}
.hero .dots i.on{background:var(--gold)}

/* MARQUEE */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;padding:20px 0;background:var(--bg)}
.marquee .track{display:flex;gap:70px;white-space:nowrap;animation:mq 30s linear infinite;width:max-content}
.marquee span{font-family:'Cormorant Garamond',serif;font-size:22px;font-style:italic;color:var(--dim);letter-spacing:.1em}
.marquee b{color:var(--gold);font-weight:400}
@keyframes mq{to{transform:translateX(-50%)}}

/* REVEAL */
.reveal{opacity:0;transform:translateY(36px);transition:opacity 1s ease,transform 1s ease}
.reveal.in{opacity:1;transform:none}

/* SECTION SHELL */
.sect{padding:120px 54px}
.sect.dark{background:var(--dark);color:var(--ink-on-dark)}
.eyebrow{font-size:11px;letter-spacing:.5em;text-transform:uppercase;color:var(--gold);margin-bottom:22px}
.h2{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:clamp(34px,4.6vw,64px);line-height:1.05}
.h2 em{font-style:italic}
.lead{margin-top:24px;font-size:15px;line-height:2;color:var(--dim);max-width:660px}
.dark .lead{color:var(--dim-on-dark)}
.btn{display:inline-block;margin-top:42px;padding:16px 42px;border:1px solid var(--gold);font-size:11px;letter-spacing:.32em;text-transform:uppercase;transition:all .35s;background:transparent;cursor:pointer;color:inherit}
.btn:hover{background:var(--gold);color:#fff}
.btn.dark-btn{color:var(--ink-on-dark)}

/* COLLECTION GRID (padding+border+nome, richiesta di Giovanni) */
.vgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:34px;margin-top:70px}
.vgrid.all{grid-template-columns:repeat(4,1fr);gap:30px}
.vcard{background:#fbf8f2;border:1px solid var(--line);padding:18px;transition:all .45s;position:relative}
.vcard:hover{border-color:var(--gold);box-shadow:0 24px 50px -28px rgba(29,26,22,.35);transform:translateY(-6px)}
.vcard .ph{overflow:hidden;aspect-ratio:1;position:relative;background:var(--dark)}
.vcard img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s ease}
.vcard:hover img{transform:scale(1.07)}
.vcard .num{position:absolute;top:26px;left:26px;z-index:2;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:20px;color:#f5f1e9;text-shadow:0 1px 8px rgba(0,0,0,.5)}
.vcard .meta{padding:18px 6px 6px;display:flex;justify-content:space-between;align-items:baseline;gap:10px}
.vcard .t{font-family:'Cormorant Garamond',serif;font-size:21px;font-weight:500}
.vcard .play{font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);white-space:nowrap}
.dark .vcard{background:var(--dark2);border-color:#2c261e}
.dark .vcard .t{color:var(--ink-on-dark)}

/* NUMBERS BAND */
.numbers{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;text-align:center;margin-top:80px}
.numbers .n{font-family:'Cormorant Garamond',serif;font-size:clamp(54px,6vw,92px);font-weight:500;color:var(--gold)}
.numbers .l{margin-top:8px;font-size:11px;letter-spacing:.4em;text-transform:uppercase;color:var(--dim-on-dark)}

/* QUOTE PARALLAX */
.bigquote{position:relative;padding:170px 10vw;text-align:center;background-attachment:fixed;background-size:cover;background-position:center;color:#f5f1e9}
.bigquote::after{content:'';position:absolute;inset:0;background:rgba(21,18,14,.72)}
.bigquote p{position:relative;z-index:2;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:clamp(28px,3.8vw,52px);line-height:1.35;max-width:1000px;margin:0 auto}
.bigquote .who{position:relative;z-index:2;margin-top:34px;font-size:11px;letter-spacing:.45em;text-transform:uppercase;color:#cdb37e}

/* SPLIT */
.vsplit{display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch}
.vsplit .img{min-height:620px;background-size:cover;background-position:center}
.vsplit .txt{padding:110px 90px;display:flex;flex-direction:column;justify-content:center}
.vsplit .txt p{font-size:15px;line-height:2.1;color:var(--dim);margin-bottom:20px}
.vsplit .txt p b{color:var(--ink);font-weight:400}
.dark .vsplit .txt p{color:var(--dim-on-dark)}
.dark .vsplit .txt p b{color:var(--ink-on-dark)}

/* VIDEO */
.vvideo{position:relative;margin:0 54px;aspect-ratio:21/9;overflow:hidden;background:var(--dark)}
.vvideo img{width:100%;height:100%;object-fit:cover;opacity:.55}
.vvideo .inner{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#f5f1e9;text-align:center}
.vplay{width:96px;height:96px;border:1px solid #cdb37e;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:26px;color:#cdb37e;transition:all .4s;cursor:pointer}
.vplay:hover{background:#cdb37e;color:var(--dark);transform:scale(1.07)}
.vvideo h3{margin-top:34px;font-family:'Cormorant Garamond',serif;font-size:clamp(26px,3vw,44px);font-weight:500}
.vvideo p{margin-top:10px;font-size:11px;letter-spacing:.4em;text-transform:uppercase;color:rgba(245,241,233,.7)}

/* PRESS BAND */
.pressband{display:flex;justify-content:center;gap:80px;flex-wrap:wrap;margin-top:60px;align-items:baseline}
.pressband .pb{font-family:'Cormorant Garamond',serif;font-size:26px;font-style:italic;color:var(--dim);transition:color .3s}
.pressband .pb:hover{color:var(--gold)}

/* PRESS CARDS */
.pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:34px;margin-top:70px}
.pcard2{background:#fbf8f2;border:1px solid var(--line);padding:50px 42px;transition:all .4s;display:flex;flex-direction:column}
.pcard2:hover{border-color:var(--gold);transform:translateY(-6px);box-shadow:0 24px 50px -28px rgba(29,26,22,.3)}
.pcard2 .src{font-size:10px;letter-spacing:.34em;text-transform:uppercase;color:var(--gold)}
.pcard2 h4{font-family:'Cormorant Garamond',serif;font-size:25px;font-style:italic;font-weight:500;margin:20px 0 16px;line-height:1.35}
.pcard2 .date{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--dim)}
.pcard2 .lnk{margin-top:auto;padding-top:26px;font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--dim)}
.pcard2:hover .lnk{color:var(--gold)}

/* EXHIBITION ROWS */
.exrow{display:grid;grid-template-columns:170px 1fr 340px;gap:44px;padding:52px 0;border-bottom:1px solid var(--line);align-items:center}
.exrow:first-of-type{border-top:1px solid var(--line);margin-top:70px}
.exrow .when{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);line-height:1.9}
.exrow h3{font-family:'Cormorant Garamond',serif;font-size:34px;font-weight:500}
.exrow .where{margin-top:10px;font-size:13px;color:var(--dim);line-height:1.9}
.exrow .img{aspect-ratio:16/10;background-size:cover;background-position:center;border:1px solid var(--line)}
.exrow .tag{display:inline-block;margin-bottom:14px;font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--dim);border:1px solid var(--line);padding:5px 12px}

/* CONTACT */
.cwrap{display:grid;grid-template-columns:1.1fr .9fr;gap:80px;margin-top:70px}
.cwrap label{display:block;font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--dim);margin-bottom:10px}
.cwrap input,.cwrap textarea{width:100%;background:transparent;border:none;border-bottom:1px solid var(--line);padding:12px 0;font-family:'Jost',sans-serif;font-size:16px;color:var(--ink);margin-bottom:38px;transition:border-color .3s}
.cwrap input:focus,.cwrap textarea:focus{outline:none;border-color:var(--gold)}
.cinfo h5{font-size:10px;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);margin:30px 0 10px}
.cinfo p{font-size:14px;line-height:2;color:var(--dim)}

/* OPERA PAGE */
.opage{display:grid;grid-template-columns:1.15fr .85fr;min-height:100vh}
.opage .media{position:relative;background:var(--dark);min-height:100vh}
.opage .media img{position:sticky;top:0;width:100%;height:100vh;object-fit:cover;opacity:.94;cursor:zoom-in}
.opage .media .vbtn{position:absolute;bottom:44px;left:44px;display:flex;align-items:center;gap:16px;color:#f5f1e9;z-index:5}
.opage .media .vbtn .vplay{width:64px;height:64px;font-size:18px}
.opage .media .vbtn span{font-size:10px;letter-spacing:.3em;text-transform:uppercase}
.opage .info{padding:150px 76px 70px;display:flex;flex-direction:column}
.opage .n{font-size:11px;letter-spacing:.4em;text-transform:uppercase;color:var(--gold)}
.opage h1{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:clamp(40px,4.2vw,68px);line-height:1.02;margin:22px 0 10px}
.opage .coll{font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--dim);margin-bottom:44px}
.ospecs{border-top:1px solid var(--line);margin-bottom:44px}
.ospecs .row{display:grid;grid-template-columns:1fr 1.4fr;padding:16px 0;border-bottom:1px solid var(--line)}
.ospecs .k{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--dim);align-self:center}
.ospecs .v{font-size:15px}
.ostory{font-family:'Cormorant Garamond',serif;font-size:21px;line-height:1.75;color:#4d483e}
.ostory em{color:var(--gold)}
.oqr{margin-top:56px;border:1px solid var(--line);background:#fbf8f2;padding:32px;display:flex;gap:28px;align-items:center}
.oqr img{width:104px;height:104px;padding:6px;background:#fff;border:1px solid var(--line)}
.oqr .t{font-size:10px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);margin-bottom:10px}
.oqr p{font-size:13px;line-height:1.8;color:var(--dim)}
.oqr code{font-size:11px;color:var(--ink)}
.opn{display:flex;justify-content:space-between;margin-top:auto;padding-top:40px;border-top:1px solid var(--line)}
.opn a{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--dim);transition:color .3s}
.opn a:hover{color:var(--gold)}

/* LIGHTBOX */
#lb{position:fixed;inset:0;background:rgba(15,13,10,.96);z-index:150;display:none;align-items:center;justify-content:center;cursor:zoom-out}
#lb.on{display:flex}
#lb img{max-width:92vw;max-height:92vh;object-fit:contain}
#lb .x{position:absolute;top:28px;right:38px;color:#f5f1e9;font-size:26px;cursor:pointer;font-family:'Jost',sans-serif}

/* FOOTER */
footer{background:var(--dark);color:var(--dim-on-dark);padding:90px 54px 50px}
footer .top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:50px}
footer .flogo{font-family:'Cormorant Garamond',serif;font-size:26px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-on-dark)}
footer .flogo em{font-style:italic;color:var(--gold)}
footer p,footer a{font-size:13px;line-height:2.2}
footer h5{font-size:10px;letter-spacing:.34em;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
footer a:hover{color:var(--ink-on-dark)}
footer .cred{margin-top:70px;padding-top:28px;border-top:1px solid #2c261e;display:flex;justify-content:space-between;font-size:11px;letter-spacing:.14em;color:#5c5546}

/* PAGE HEAD (inner pages) */
.phead{padding:200px 54px 60px;text-align:center}
.phead .eyebrow{margin-bottom:26px}
.phead h1{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:clamp(44px,6vw,88px);line-height:1}
.phead h1 em{font-style:italic}
.phead .lead{margin:26px auto 0}

@media(max-width:1100px){
 .vgrid.all{grid-template-columns:repeat(3,1fr)}
 .opage{grid-template-columns:1fr}
 .opage .media{min-height:64vh}
 .opage .media img{position:relative;height:64vh}
 .opage .info{padding:70px 34px}
}
@media(max-width:860px){
 nav{padding:20px 26px}nav.scrolled{padding:12px 26px}
 nav ul{display:none}
 nav .burger{display:block;font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:inherit;cursor:pointer;border:1px solid var(--line);padding:7px 14px}
 nav.open ul{display:flex;flex-direction:column;position:fixed;inset:0;background:var(--bg);align-items:center;justify-content:center;gap:34px;z-index:99}
 nav.open ul a{font-size:15px;color:var(--ink)}
 .sect{padding:80px 26px}
 .vgrid,.vgrid.all,.pgrid{grid-template-columns:1fr 1fr;gap:20px}
 .vsplit{grid-template-columns:1fr}
 .vsplit .txt{padding:60px 30px}
 .vvideo{margin:0 26px;aspect-ratio:16/10}
 .exrow{grid-template-columns:1fr;gap:20px}
 .cwrap{grid-template-columns:1fr;gap:40px}
 footer{padding:70px 26px 40px}
 footer .top{grid-template-columns:1fr}
 .numbers{grid-template-columns:1fr;gap:30px}
 .phead{padding:160px 26px 40px}
}
@media(max-width:540px){.vgrid,.vgrid.all,.pgrid{grid-template-columns:1fr}}
