:root{
  --ivory:#faf7f1;
  --paper:#fffdf9;
  --ink:#2c2823;
  --muted:#8b8276;
  --line:#e7ddcd;
  --gold:#b08d57;
  --gold-soft:#c8a97e;
  --shadow:0 18px 50px -22px rgba(60,46,28,.45);
  --radius:14px;
  --maxw:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--ivory);
  color:var(--ink);
  font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  font-weight:300;
  -webkit-font-smoothing:antialiased;
  line-height:1.6;
}
img{display:block;max-width:100%}
h1,h2,h3{font-family:"Cormorant Garamond",Georgia,serif;font-weight:500;margin:0;letter-spacing:.01em}

/* ---------- NAV ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:16px clamp(18px,5vw,48px);
  transition:background .35s ease, box-shadow .35s ease, padding .35s ease;
}
.nav.scrolled{background:rgba(255,253,249,.86);backdrop-filter:blur(12px);box-shadow:0 1px 0 var(--line);padding-top:12px;padding-bottom:12px}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none;color:inherit}
.brand-mark{font-size:22px}
.brand-text{font-family:"Cormorant Garamond",serif;font-size:23px;font-weight:600;letter-spacing:.04em;color:#fff;text-shadow:0 1px 14px rgba(0,0,0,.35);transition:color .35s,text-shadow .35s}
.nav.scrolled .brand-text{color:var(--ink);text-shadow:none}
.nav-links{display:flex;align-items:center;gap:clamp(14px,3vw,30px)}
.nav-links a{text-decoration:none;color:#fff;font-size:14px;letter-spacing:.06em;text-transform:uppercase;font-weight:400;text-shadow:0 1px 12px rgba(0,0,0,.4);transition:color .35s,opacity .2s}
.nav-links a:hover{opacity:.7}
.nav.scrolled .nav-links a{color:var(--ink);text-shadow:none}
.nav-cta{border:1px solid rgba(255,255,255,.6);border-radius:999px;padding:8px 18px!important}
.nav.scrolled .nav-cta{border-color:var(--gold);color:var(--gold)!important}

/* ---------- HERO ---------- */
.hero{position:relative;height:100vh;min-height:560px;display:flex;align-items:center;justify-content:center;overflow:hidden;text-align:center}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center 32%;transform:scale(1.05);animation:slowzoom 18s ease-out forwards}
@keyframes slowzoom{to{transform:scale(1.14)}}
.hero-veil{position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(20,15,8,.42),rgba(20,15,8,.18) 40%,rgba(20,15,8,.5));}
.hero-inner{position:relative;color:#fff;padding:0 24px;max-width:760px}
.hero-kicker{font-size:13px;letter-spacing:.32em;text-transform:uppercase;margin:0 0 18px;opacity:.92;font-weight:400}
.hero-title{font-size:clamp(56px,12vw,128px);line-height:.95;font-weight:500;text-shadow:0 4px 40px rgba(0,0,0,.35)}
.hero-title::after{content:"";display:block;width:80px;height:1px;background:var(--gold-soft);margin:26px auto 0;opacity:.9}
.hero-sub{margin:22px 0 0;font-size:16px;letter-spacing:.14em;text-transform:uppercase;opacity:.92}
.hero-scroll{position:absolute;left:50%;bottom:34px;transform:translateX(-50%);color:#fff;text-decoration:none;font-size:26px;opacity:.8;animation:bob 2.4s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,8px)}}

/* ---------- BLOCKS ---------- */
.block{padding:clamp(64px,9vw,118px) clamp(18px,5vw,48px);max-width:var(--maxw);margin:0 auto}
.block.alt{max-width:none;background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.block.alt .block-head,.block.alt .masonry{max-width:var(--maxw);margin-left:auto;margin-right:auto}
.block-head{text-align:center;max-width:620px;margin:0 auto clamp(36px,5vw,56px)}
.eyebrow{font-size:12px;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin:0 0 14px;font-weight:500}
.block-head h2{font-size:clamp(34px,5vw,52px);line-height:1.05}
.lead{margin:16px auto 0;color:var(--muted);font-size:16.5px;max-width:540px}

/* ---------- MASONRY ---------- */
.masonry{column-count:3;column-gap:18px}
.masonry.small{column-count:4;column-gap:14px}
@media(max-width:900px){.masonry{column-count:2}.masonry.small{column-count:3}}
@media(max-width:560px){.masonry{column-count:1}.masonry.small{column-count:2}}
.tile{position:relative;break-inside:avoid;margin-bottom:18px;border-radius:var(--radius);overflow:hidden;cursor:pointer;background:#efe7d8;box-shadow:var(--shadow);opacity:0;transform:translateY(14px);transition:opacity .6s ease,transform .6s ease}
.masonry.small .tile{margin-bottom:14px;border-radius:10px}
.tile.in{opacity:1;transform:none}
.tile img{width:100%;height:auto;transition:transform .7s cubic-bezier(.2,.7,.2,1)}
.tile:hover img{transform:scale(1.05)}
.tile::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 55%,rgba(0,0,0,.4));opacity:0;transition:opacity .4s}
.tile:hover::after{opacity:1}
.tile-cap{position:absolute;left:14px;bottom:12px;right:14px;color:#fff;font-family:"Cormorant Garamond",serif;font-size:20px;opacity:0;transform:translateY(6px);transition:opacity .4s,transform .4s;z-index:2;text-shadow:0 1px 10px rgba(0,0,0,.5)}
.tile:hover .tile-cap{opacity:1;transform:none}
.tile-zoom{position:absolute;top:12px;right:12px;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.9);display:grid;place-items:center;font-size:15px;opacity:0;transform:scale(.8);transition:.3s;z-index:2}
.tile:hover .tile-zoom{opacity:1;transform:scale(1)}

/* ---------- DOWNLOAD ---------- */
.block.download{text-align:center}
.dl-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;max-width:840px;margin:0 auto}
@media(max-width:680px){.dl-cards{grid-template-columns:1fr}}
.dl-card{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:38px 30px;box-shadow:var(--shadow);text-align:center}
.dl-icon{font-size:34px;margin-bottom:10px}
.dl-card h3{font-size:28px;margin-bottom:6px}
.dl-meta{color:var(--gold);font-size:13px;letter-spacing:.08em;text-transform:uppercase;margin:0 0 14px}
.dl-desc{color:var(--muted);font-size:15px;margin:0 auto 24px;max-width:300px;min-height:48px}
.btn{appearance:none;border:none;cursor:pointer;font-family:inherit;font-size:14.5px;font-weight:500;letter-spacing:.04em;color:#fff;background:var(--gold);padding:14px 26px;border-radius:999px;transition:transform .2s,box-shadow .2s,background .2s;box-shadow:0 10px 24px -10px rgba(176,141,87,.8)}
.btn:hover{transform:translateY(-2px);background:#a07f4b}
.btn:disabled{opacity:.6;cursor:progress;transform:none}
.btn.ghost{background:transparent;color:var(--gold);border:1.5px solid var(--gold);box-shadow:none}
.btn.ghost:hover{background:var(--gold);color:#fff}
.progress{height:0;overflow:hidden;opacity:0;transition:.3s;margin-top:16px}
.progress.on{height:auto;opacity:1}
.progress .bar{height:6px;border-radius:6px;background:var(--line);position:relative;overflow:hidden}
.progress .bar::after{content:"";position:absolute;left:0;top:0;bottom:0;width:var(--p,0%);background:var(--gold-soft);transition:width .25s}
.progress .ptxt{display:block;margin-top:8px;font-size:12.5px;color:var(--muted);letter-spacing:.04em}
.dl-foot{margin-top:36px;color:var(--muted);font-size:14.5px}
.dl-foot em{color:var(--ink);font-style:normal;font-weight:500}

/* ---------- FOOTER ---------- */
.foot{text-align:center;padding:54px 24px;border-top:1px solid var(--line);color:var(--muted)}
.foot p{margin:4px 0;font-family:"Cormorant Garamond",serif;font-size:18px}
.foot-dim{font-size:13px!important;font-family:"Inter",sans-serif!important;letter-spacing:.1em}

/* ---------- LIGHTBOX ---------- */
.lb{position:fixed;inset:0;z-index:100;background:rgba(18,14,9,.94);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s}
.lb.open{opacity:1;pointer-events:auto}
.lb-stage{margin:0;max-width:92vw;max-height:80vh;display:flex;flex-direction:column;align-items:center}
.lb-stage img{max-width:92vw;max-height:74vh;border-radius:6px;box-shadow:0 30px 80px -20px rgba(0,0,0,.8);object-fit:contain}
.lb-stage figcaption{color:#f1e9da;font-family:"Cormorant Garamond",serif;font-size:22px;margin-top:16px;text-align:center;min-height:1em}
.lb-close,.lb-nav{position:absolute;background:rgba(255,255,255,.1);border:none;color:#fff;cursor:pointer;border-radius:50%;display:grid;place-items:center;transition:background .2s,transform .2s}
.lb-close:hover,.lb-nav:hover{background:rgba(255,255,255,.22)}
.lb-close{top:22px;right:24px;width:46px;height:46px;font-size:18px}
.lb-nav{top:50%;transform:translateY(-50%);width:54px;height:54px;font-size:30px}
.lb-nav.prev{left:18px}
.lb-nav.next{right:18px}
.lb-dl{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);color:var(--ink);background:rgba(255,253,249,.95);text-decoration:none;padding:12px 24px;border-radius:999px;font-size:14px;font-weight:500;letter-spacing:.03em;transition:transform .2s}
.lb-dl:hover{transform:translateX(-50%) translateY(-2px)}
@media(max-width:560px){.lb-nav{width:44px;height:44px;font-size:24px}.lb-stage img{max-height:66vh}}

/* ---------- TOAST ---------- */
.toast{position:fixed;left:50%;bottom:28px;transform:transl(-50%,20px);translate:-50% 20px;background:var(--ink);color:#fff;padding:12px 22px;border-radius:999px;font-size:14px;opacity:0;pointer-events:none;transition:.3s;z-index:200}
.toast.show{opacity:1;translate:-50% 0}
