*{margin:0;padding:0;box-sizing:border-box}
:root{--gold:#C4A04A;--gold2:#E2C46A;--black:#080808;--black2:#101010;--black3:#181818;--cream:#F2EDE4;--muted:#A09880}
html{scroll-behavior:smooth}
body{background:var(--black);color:var(--cream);font-family:'Jost',sans-serif;font-weight:300;overflow-x:hidden}
img{display:block;width:100%;object-fit:cover}
a{text-decoration:none;color:inherit}

.col-photo{aspect-ratio:3/4;background-size:cover;background-position:center}
.gal-item{aspect-ratio:3/4;background-size:cover;background-position:center}

/* INTRO OVERLAY */
#intro{position:fixed;inset:0;z-index:10000;background:var(--black);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:12px;pointer-events:none}
#intro .i-logo{font-family:'Cinzel',serif;font-size:clamp(28px,8vw,72px);letter-spacing:clamp(8px,3vw,28px);color:var(--gold);opacity:0;transform:translateY(20px);transition:opacity .8s ease,transform .8s ease;text-align:center;padding:0 20px;word-break:break-word}
#intro .i-tag{font-size:9px;letter-spacing:8px;text-transform:uppercase;color:var(--muted);opacity:0;transition:opacity .6s ease .4s}
#intro.hide{opacity:0;transition:opacity .6s ease .2s}

/* CURSOR */
@media(pointer:fine){
  body{cursor:none}
  #cur{width:8px;height:8px;background:var(--gold);border-radius:50%;position:fixed;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:transform .15s ease;mix-blend-mode:difference}
  #cur-ring{width:32px;height:32px;border:1px solid rgba(196,160,74,.6);border-radius:50%;position:fixed;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:left .08s ease,top .08s ease}
}

/* NAV */
#nav{position:fixed;top:0;left:0;right:0;z-index:999;display:flex;align-items:center;justify-content:space-between;padding:0 40px;height:76px;transition:background .4s,height .3s}
#nav.solid{background:rgba(8,8,8,.97);border-bottom:1px solid rgba(196,160,74,.12);height:62px}
.nav-logo{display:flex;flex-direction:column;gap:3px;flex-shrink:0}
.nav-logo .ag{font-family:'Cinzel',serif;font-size:22px;letter-spacing:8px;color:var(--gold);line-height:1}
.nav-logo .sub{font-size:7px;letter-spacing:5px;color:var(--muted);text-transform:uppercase}
.nav-center{position:absolute;left:50%;transform:translateX(-50%);display:flex;gap:36px;list-style:none}
.nav-center a{font-size:9px;letter-spacing:4px;text-transform:uppercase;color:var(--muted);transition:all .3s;padding-bottom:2px;border-bottom:1px solid transparent}
.nav-center a:hover{color:var(--gold);border-bottom-color:var(--gold)}
.nav-right{flex-shrink:0}
.nav-wa{font-size:8px;letter-spacing:3px;text-transform:uppercase;border:1px solid var(--gold);color:var(--gold);padding:9px 20px;transition:all .3s;white-space:nowrap}
.nav-wa:hover{background:var(--gold);color:var(--black)}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px}
.burger span{display:block;width:22px;height:1px;background:var(--gold)}

/* MOBILE MENU */
#mob{display:none;position:fixed;inset:0;z-index:1000;background:rgba(8,8,8,.99);flex-direction:column;align-items:center;justify-content:center;gap:32px}
#mob.on{display:flex}
#mob a{font-family:'Cinzel',serif;font-size:18px;letter-spacing:6px;text-transform:uppercase;color:var(--cream);transition:color .3s}
#mob a:hover{color:var(--gold)}
.mob-wa{background:var(--gold);color:var(--black) !important;padding:13px 36px;font-size:11px !important;letter-spacing:3px !important;margin-top:12px}
.mob-x{position:absolute;top:24px;right:28px;font-size:24px;color:var(--gold);background:none;border:none;cursor:pointer;line-height:1}

/* HERO */
#hero{position:relative;height:100svh;min-height:620px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-dim{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(8,8,8,.5) 0%,rgba(8,8,8,.2) 40%,rgba(8,8,8,.8) 100%)}
.hero-body{position:relative;z-index:2;text-align:center;padding:0 24px 80px;animation:up .9s ease both}
@keyframes up{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.hero-pre{font-size:8px;letter-spacing:8px;text-transform:uppercase;color:var(--gold);margin-bottom:22px}
.hero-h1{font-family:'Cinzel',serif;font-size:clamp(38px,9vw,90px);font-weight:400;letter-spacing:clamp(6px,2vw,20px);line-height:1;text-transform:uppercase;color:var(--cream)}
.hero-tag{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:clamp(16px,3vw,26px);color:var(--muted);letter-spacing:3px;margin-top:16px}
.hero-rule{width:56px;height:1px;background:var(--gold);margin:30px auto}
.hero-btns{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}
.btn-g{background:var(--gold);color:var(--black);font-size:9px;letter-spacing:4px;text-transform:uppercase;padding:14px 30px;transition:all .3s}
.btn-g:hover{background:var(--gold2)}
.btn-o{border:1px solid rgba(196,160,74,.5);color:var(--cream);font-size:9px;letter-spacing:4px;text-transform:uppercase;padding:14px 30px;transition:all .3s}
.btn-o:hover{border-color:var(--gold);color:var(--gold)}
.hero-scroll{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:7px;font-size:7px;letter-spacing:3px;text-transform:uppercase;color:var(--muted);animation:up .9s .8s ease both}
.scroll-bar{width:1px;height:34px;background:linear-gradient(var(--gold),transparent);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:.3}50%{opacity:1}}

/* TICKER */
.ticker{overflow:hidden;white-space:nowrap;background:var(--gold);padding:12px 0}
.ticker-inner{display:inline-flex;animation:tick 28s linear infinite}
.ticker-inner span{font-family:'Cinzel',serif;font-size:9px;letter-spacing:6px;text-transform:uppercase;color:var(--black);padding:0 28px}
.ticker-inner em{color:rgba(0,0,0,.3);font-style:normal;padding:0 4px}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* LAYOUT */
.wrap{max-width:1200px;margin:0 auto;padding:0 40px}
.sec{padding:100px 0}
.sec-label{font-size:8px;letter-spacing:6px;text-transform:uppercase;color:var(--gold);margin-bottom:10px}
.sec-title{font-family:'Cinzel',serif;font-size:clamp(22px,4vw,42px);font-weight:400;letter-spacing:4px;text-transform:uppercase;line-height:1.2}
.sec-rule{width:48px;height:1px;background:var(--gold);margin:20px 0}

/* ABOUT */
#about{background:var(--black2)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-img-wrap{position:relative}
.about-img-wrap::before{content:'';position:absolute;top:-14px;left:-14px;right:14px;bottom:14px;border:1px solid rgba(196,160,74,.2);z-index:0}
.about-img-wrap img{position:relative;z-index:1;aspect-ratio:3/4}
.about-stamp{position:absolute;bottom:-18px;right:-18px;z-index:2;width:86px;height:86px;background:var(--gold);display:flex;flex-direction:column;align-items:center;justify-content:center;font-family:'Cinzel',serif;color:var(--black)}
.about-stamp .s1{font-size:22px;font-weight:500;line-height:1}
.about-stamp .s2{font-size:6px;letter-spacing:2px;text-align:center;margin-top:2px}
.about-body p{font-size:14px;line-height:2;color:var(--muted);margin-bottom:16px}
.about-body strong{color:var(--gold);font-weight:400}
.tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px}
.tags span{border:1px solid rgba(196,160,74,.2);padding:6px 14px;font-size:8px;letter-spacing:3px;text-transform:uppercase;color:var(--muted)}

/* COLLECTIONS */
#collections{background:var(--black)}
.col-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:48px;flex-wrap:wrap;gap:16px}
.col-list{display:flex;flex-direction:column;gap:2px}
.col-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;padding:24px 28px;background:var(--black2);cursor:pointer;border:none;border-left:2px solid transparent;transition:background .3s,border-color .3s}
.col-trigger:hover,.col-trigger.open{background:var(--black3);border-left:2px solid var(--gold)}
.col-tl{display:flex;align-items:center;gap:22px}
.col-num{font-family:'Cinzel',serif;font-size:11px;color:var(--gold);letter-spacing:2px;opacity:.55;min-width:28px}
.col-name{font-family:'Cinzel',serif;font-size:clamp(14px,2.5vw,21px);letter-spacing:3px;text-transform:uppercase;color:var(--cream)}
.col-arrow{font-size:22px;color:var(--gold);transition:transform .4s;line-height:1;flex-shrink:0}
.col-trigger.open .col-arrow{transform:rotate(45deg)}
.col-panel{max-height:0;overflow:hidden;transition:max-height .65s cubic-bezier(.4,0,.2,1)}
.col-panel.open{max-height:6000px}
.col-photos{display:grid;grid-template-columns:repeat(4,1fr);gap:3px;padding:3px 0}
.col-photo{position:relative;overflow:hidden;cursor:pointer}
.col-photo img{aspect-ratio:3/4;transition:transform .5s,filter .4s;filter:brightness(.82)}
.col-photo:hover img{transform:scale(1.05);filter:brightness(1)}

/* SUB-SECTIONS inside collections */
.sub-section{padding:20px 0 0}
.sub-label{font-size:8px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);opacity:.7;padding:16px 0 10px;border-top:1px solid rgba(196,160,74,.1)}

/* SHOW MORE */
.col-hidden{display:none}
.show-more-btn{display:block;width:100%;padding:13px;margin-top:3px;background:transparent;border:1px solid rgba(196,160,74,.2);color:var(--gold);font-family:'Jost',sans-serif;font-size:8px;letter-spacing:4px;text-transform:uppercase;cursor:pointer;transition:all .3s}
.show-more-btn:hover{background:rgba(196,160,74,.06);border-color:var(--gold)}
.show-more-btn.hidden{display:none}

.col-foot{display:flex;justify-content:center;padding:20px;background:var(--black3)}
.wa-btn{display:inline-flex;align-items:center;gap:10px;background:var(--gold);color:var(--black);padding:13px 30px;font-size:9px;letter-spacing:3px;text-transform:uppercase;transition:all .3s}
.wa-btn:hover{background:var(--gold2);transform:translateY(-2px)}
.wa-btn svg{width:16px;height:16px;fill:var(--black);flex-shrink:0}

/* GALLERY */
/* Grid uses fixed aspect-ratio so every photo is the same size — no odd one out */
#gallery{background:var(--black2)}
.gal-header{margin-bottom:0}
.gal-sub{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:clamp(14px,2vw,18px);color:var(--muted);margin-top:8px}
.gal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px;margin-top:40px}
.gal-item{overflow:hidden;position:relative;cursor:pointer;aspect-ratio:3/4}
.gal-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s,filter .4s;filter:brightness(.82)}
.gal-item:hover img{transform:scale(1.04);filter:brightness(1.02)}
.gal-over{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s;background:rgba(196,160,74,.05)}
.gal-item:hover .gal-over{opacity:1}
.gal-over span{font-family:'Cinzel',serif;font-size:9px;letter-spacing:4px;text-transform:uppercase;color:var(--cream);border:1px solid var(--gold);padding:9px 18px}

/* LIGHTBOX */
#lb{display:none;position:fixed;inset:0;z-index:8000;background:rgba(8,8,8,.97);align-items:center;justify-content:center}
#lb.on{display:flex}
#lb-img{max-height:90vh;max-width:90vw;object-fit:contain;animation:lbIn .3s ease}
@keyframes lbIn{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
#lb-close{position:absolute;top:24px;right:32px;font-size:28px;color:var(--gold);cursor:pointer;background:none;border:none;line-height:1;font-family:'Cinzel',serif}
#lb-prev,#lb-next{position:absolute;top:50%;transform:translateY(-50%);font-size:28px;color:var(--gold);background:none;border:none;cursor:pointer;padding:20px;opacity:.7;transition:opacity .2s}
#lb-prev{left:20px}#lb-next{right:20px}
#lb-prev:hover,#lb-next:hover{opacity:1}
#lb-counter{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);font-size:9px;letter-spacing:4px;color:var(--muted)}

/* ORDER */
#order{background:var(--black3);text-align:center;position:relative;overflow:hidden}
#order::before{content:'AG';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:'Cinzel',serif;font-size:260px;color:rgba(196,160,74,.03);pointer-events:none;white-space:nowrap}
.order-inner{position:relative;z-index:1;max-width:660px;margin:0 auto}
.order-inner p{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:clamp(15px,2vw,21px);color:var(--muted);line-height:1.9;margin:20px 0 38px}
.wa-main{display:inline-flex;align-items:center;gap:13px;background:var(--gold);color:var(--black);padding:17px 44px;font-size:10px;letter-spacing:4px;text-transform:uppercase;transition:all .3s}
.wa-main:hover{background:var(--gold2);transform:translateY(-2px);box-shadow:0 10px 32px rgba(196,160,74,.25)}
.wa-main svg{width:20px;height:20px;fill:var(--black)}
.order-note{margin-top:20px;font-size:9px;letter-spacing:2px;color:var(--muted);opacity:.5}

/* CONTACT */
#contact{background:var(--black)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px}
.c-detail{display:flex;gap:14px;margin-bottom:22px;align-items:flex-start}
.c-icon{width:38px;height:38px;border:1px solid rgba(196,160,74,.2);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.c-text{font-size:13px;color:var(--muted);line-height:1.7}
.c-text strong{display:block;font-size:8px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:3px;font-weight:400}
.socials{display:flex;gap:8px;margin-top:32px}
.soc{width:42px;height:42px;border:1px solid rgba(196,160,74,.2);display:flex;align-items:center;justify-content:center;color:var(--muted);transition:all .3s}
.soc:hover{border-color:var(--gold);color:var(--gold)}
.soc svg{width:16px;height:16px;fill:currentColor}
.form{display:flex;flex-direction:column;gap:14px}
.form label{font-size:8px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:5px}
.form input,.form select,.form textarea{width:100%;background:transparent;border:1px solid rgba(196,160,74,.15);color:var(--cream);padding:12px 14px;font-family:'Jost',sans-serif;font-size:13px;outline:none;transition:border-color .3s;-webkit-appearance:none}
.form input:focus,.form select:focus,.form textarea:focus{border-color:var(--gold)}
.form select option{background:var(--black)}
.form textarea{min-height:100px;resize:vertical}
.form-btn{background:var(--gold);color:var(--black);border:none;padding:14px;font-family:'Jost',sans-serif;font-size:9px;letter-spacing:4px;text-transform:uppercase;cursor:pointer;transition:all .3s;width:100%}
.form-btn:hover{background:var(--gold2)}
.form-err{color:#e05;font-size:11px;letter-spacing:1px;display:none;margin-top:4px}

/* FOOTER */
footer{background:var(--black2);border-top:1px solid rgba(196,160,74,.1);padding:36px 40px}
.footer-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:20px}
.f-logo .ag{font-family:'Cinzel',serif;font-size:18px;letter-spacing:6px;color:var(--gold)}
.f-logo .sub{font-size:7px;letter-spacing:4px;color:var(--muted);text-transform:uppercase;margin-top:3px}
.f-nav{display:flex;gap:24px}
.f-nav a{font-size:8px;letter-spacing:3px;text-transform:uppercase;color:var(--muted);transition:color .3s}
.f-nav a:hover{color:var(--gold)}
.f-copy{font-size:9px;color:var(--muted);opacity:.4;letter-spacing:1px}
.f-credit{max-width:1200px;margin:20px auto 0;padding-top:18px;border-top:1px solid rgba(196,160,74,.07);display:flex;align-items:center;justify-content:center;gap:10px}
.f-credit-label{font-size:8px;letter-spacing:3px;text-transform:uppercase;color:var(--muted);opacity:.5}
.f-credit-name{font-family:'Cinzel',serif;font-size:10px;letter-spacing:4px;text-transform:uppercase;color:var(--gold);opacity:.75;border-bottom:1px solid rgba(196,160,74,.25);padding-bottom:1px;transition:opacity .3s,border-color .3s}
.f-credit-name:hover{opacity:1;border-bottom-color:var(--gold)}

/* REVEAL */
.r{opacity:0;transform:translateY(28px);transition:opacity .8s ease,transform .8s ease}
.r.in{opacity:1;transform:none}

/* RESPONSIVE */
@media(max-width:900px){
  .nav-center{display:none}
  .nav-wa{display:none}
  .burger{display:flex}
  .about-grid,.contact-grid{grid-template-columns:1fr;gap:40px}
  .col-photos{grid-template-columns:repeat(2,1fr)}
  .gal-grid{grid-template-columns:repeat(2,1fr)}
  .wrap{padding:0 20px}
  #nav{padding:0 20px}
}
@media(max-width:560px){
  .gal-grid{grid-template-columns:repeat(2,1fr)}
  .col-photos{grid-template-columns:repeat(2,1fr)}
  #lb-prev,#lb-next{padding:10px;font-size:20px}
}
