@import url('https://fonts.googleapis.com/css2?family=DM+Mono:ital,wght@0,300;0,400;0,500;1,300&family=Newsreader:ital,opsz,wght@0,6..72,200;0,6..72,300;0,6..72,400;1,6..72,200;1,6..72,300;1,6..72,400&family=Geist:wght@300;400;500;600&display=swap');

:root {
  --bg:       #F5F3ED;
  --bg2:      #EDE9DD;
  --bg3:      #E5DFCB;
  --ink:      #2D2A22;
  --ink2:     #5A574A;
  --ink3:     #959280;
  --line:     #D6D1BE;
  --line2:    #C4BEAA;
  --accent:   #B86B46;
  --acc-bg:   rgba(184,107,70,.08);
  --acc-light:rgba(184,107,70,.15);
  --danger:   #C33;
  --dan-bg:   #F9E8E8;
  --r:        4px;
  --r2:       8px;
  --r3:       16px;
  --r4:       24px;
  --pill:     100px;
  --sh:       0 1px 2px rgba(0,0,0,.04);
  --sh2:      0 2px 8px rgba(0,0,0,.06),0 12px 32px rgba(0,0,0,.04);
  --sh3:      0 4px 12px rgba(0,0,0,.08),0 24px 64px rgba(0,0,0,.06);
  --ease:     cubic-bezier(.25,.1,.25,1);
  --out:      cubic-bezier(0,0,.2,1);
  --spring:   cubic-bezier(.16,1,.3,1);
  --t:        .2s cubic-bezier(.25,.1,.25,1);
  --ts:       .4s cubic-bezier(0,0,.2,1);
}

[data-theme="dark"] {
  --bg:       #0D0D0C;
  --bg2:      #161615;
  --bg3:      #1F1F1E;
  --ink:      #EDEBE7;
  --ink2:     #8A897F;
  --ink3:     #605F57;
  --line:     #282826;
  --line2:    #3A3937;
  --accent:   #E08A6A;
  --acc-bg:   rgba(224,138,106,.1);
  --acc-light:rgba(224,138,106,.2);
  --danger:   #E05050;
  --dan-bg:   #1E0808;
  --sh:       0 1px 2px rgba(0,0,0,.4);
  --sh2:      0 2px 8px rgba(0,0,0,.4),0 12px 32px rgba(0,0,0,.3);
  --sh3:      0 4px 12px rgba(0,0,0,.5),0 24px 64px rgba(0,0,0,.35);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Geist',system-ui,-apple-system,sans-serif;
  background:var(--bg);color:var(--ink);
  font-size:16px;line-height:1.6;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
img{max-width:100%;display:block}
ul,ol{list-style:none}
input,textarea{font-family:inherit}

.container{width:100%;max-width:1200px;margin:0 auto;padding:0 48px}
.section{padding:clamp(72px,8vw,128px) 0;position:relative}

.eyebrow{
  font-family:'DM Mono',monospace;
  font-size:11px;font-weight:400;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--accent);display:inline-flex;align-items:center;gap:8px;
  margin-bottom:28px;
}
.eyebrow::before{
  content:'';display:block;width:28px;height:1px;background:var(--accent);
}

.section-title{
  font-family:'Newsreader',Georgia,serif;
  font-size:clamp(36px,5vw,64px);font-weight:300;
  line-height:1;letter-spacing:-.04em;
  margin-bottom:20px;
}
.section-sub{
  font-size:clamp(16px,1.2vw,19px);color:var(--ink2);
  font-weight:300;line-height:1.7;
  max-width:540px;margin-bottom:clamp(48px,6vw,80px);
}

.hero{
  min-height:100vh;
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
  background:var(--bg);
}
.hero::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 80% 60% at 50% 20%,rgba(184,107,70,.06),transparent 50%),
    radial-gradient(ellipse 60% 40% at 50% 100%,rgba(184,107,70,.03),transparent 40%);
  pointer-events:none;
}
.hero::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 50% 50%,transparent 30%,var(--bg) 70%);
  pointer-events:none;
}

.hero-inner{
  width:100%;max-width:1100px;margin:0 auto;padding:0 48px;
  display:grid;grid-template-columns:1fr 1fr;
  align-items:center;gap:64px;
  position:relative;z-index:1;
  min-height:calc(100vh - 80px);
}
.hero-content{text-align:left}
.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  font-family:'DM Mono',monospace;font-size:11px;
  letter-spacing:.1em;text-transform:uppercase;
  color:var(--danger);margin-bottom:40px;
  padding:8px 20px;
  background:var(--dan-bg);border:1px solid rgba(195,51,51,.2);
  border-radius:var(--pill);
  opacity:0;
  transform:translateY(20px);
  animation:fade-up 0.8s var(--spring) 0.2s forwards;
}
.hero-badge::before{
  content:'';width:6px;height:6px;border-radius:50%;
  background:var(--danger);
  animation:pulse-dot 2s ease infinite;
}
@keyframes pulse-dot{
  0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(195,51,51,.4)}
  50%{opacity:.6;box-shadow:0 0 0 6px rgba(195,51,51,0)}
}

.hero-title{
  font-family:'Newsreader',Georgia,serif;
  font-size:clamp(48px,7vw,96px);font-weight:300;
  line-height:.95;letter-spacing:-.04em;
  margin-bottom:32px;
  opacity:0;
  transform:translateY(30px);
  animation:fade-up 1s var(--spring) 0.4s forwards;
}
.hero-title .rest{
  display:block;
  font-size:clamp(24px,3.5vw,42px);
  font-weight:300;
  color:var(--ink3);
  letter-spacing:-.02em;
  margin-top:8px;
}

.hero-sub{
  font-size:clamp(16px,1.3vw,20px);font-weight:300;color:var(--ink2);
  line-height:1.7;max-width:480px;
  opacity:0;
  transform:translateY(24px);
  animation:fade-up 0.9s var(--spring) 0.6s forwards;
}

.hero-credits{
  margin-top:48px;
  display:flex;flex-direction:column;gap:8px;
  font-family:'DM Mono',monospace;font-size:12px;color:var(--ink3);
  opacity:0;
  transform:translateY(20px);
  animation:fade-up 0.8s var(--spring) 0.8s forwards;
}
.hero-credits span{color:var(--ink2)}

.hero-tomb{
  display:flex;align-items:flex-end;justify-content:center;
  opacity:0;
  transform:translateY(30px) scale(0.95);
  animation:tomb-rise 1s var(--spring) 0.5s forwards;
}
@keyframes tomb-rise{
  to{opacity:1;transform:translateY(0) scale(1)}
}
.hero-tomb svg{
  width:100%;max-width:280px;height:auto;
  filter:drop-shadow(0 30px 50px rgba(0,0,0,.12));
}

@media(max-width:768px){
  .hero-inner{grid-template-columns:1fr;text-align:center}
  .hero-content{order:1}
  .hero-tomb{order:2;margin-top:48px}
  .hero-sub{margin:0 auto}
}

@keyframes fade-up{
  to{opacity:1;transform:translateY(0)}
}

.gallery-section{
  padding:clamp(64px,8vw,112px) 0;
  position:relative;
}
.gallery-section::before,
.oldsection::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--line),transparent);
}

.oldsection{
  padding:clamp(64px,8vw,112px) 0;
  position:relative;
  background:var(--bg);
}

.gallery-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:24px;
  margin-top:56px;
}

.gallery-item{
  position:relative;
  border-radius:var(--r4);
  overflow:hidden;
  background:var(--bg2);
  border:1px solid var(--line);
  aspect-ratio:4/3;
  opacity:0;
  transform:translateY(40px) scale(0.96);
}
.gallery-item.visible{
  animation:gallery-rise 0.8s var(--spring) forwards;
}
@keyframes gallery-rise{
  to{opacity:1;transform:translateY(0) scale(1)}
}

.gallery-item:nth-child(1){animation-delay:0.1s}
.gallery-item:nth-child(2){animation-delay:0.2s}
.gallery-item:nth-child(3){animation-delay:0.3s}
.gallery-item:nth-child(4){animation-delay:0.4s}
.gallery-item:nth-child(5){animation-delay:0.5s}
.gallery-item:nth-child(6){animation-delay:0.6s}

.gallery-item img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 0.6s var(--spring),opacity 0.4s ease;
  opacity:0.85;
}
.gallery-item:hover img{
  transform:scale(1.05);
  opacity:1;
}

.gallery-item-overlay{
  position:absolute;bottom:0;left:0;right:0;
  padding:24px;
  background:linear-gradient(to top,rgba(0,0,0,.7) 0%,transparent 100%);
  transform:translateY(100%);
  transition:transform 0.4s var(--spring);
}
.gallery-item:hover .gallery-item-overlay{
  transform:translateY(0);
}
.gallery-item-label{
  font-family:'DM Mono',monospace;font-size:11px;
  color:#fff;letter-spacing:.06em;text-transform:uppercase;
}
.gallery-item-title{
  font-family:'Newsreader',Georgia,serif;font-size:18px;
  color:#fff;font-weight:300;margin-top:4px;
}

.timeline-section{
  padding:clamp(64px,8vw,112px) 0;
}

.timeline{
  max-width:720px;margin:56px auto 0;
  position:relative;
}
.timeline::before{
  content:'';position:absolute;left:24px;top:0;bottom:0;
  width:1px;background:var(--line);
}
@media(min-width:640px){
  .timeline::before{left:50%}
}

.timeline-item{
  position:relative;
  padding:32px 0 32px 64px;
  opacity:0;
  transform:translateX(-20px);
}
.timeline-item.visible{
  animation:slide-in 0.7s var(--spring) forwards;
}
@keyframes slide-in{
  to{opacity:1;transform:translateX(0)}
}

.timeline-item:nth-child(1){animation-delay:0.15s}
.timeline-item:nth-child(2){animation-delay:0.3s}
.timeline-item:nth-child(3){animation-delay:0.45s}
.timeline-item:nth-child(4){animation-delay:0.6s}
.timeline-item:nth-child(5){animation-delay:0.75s}

@media(min-width:640px){
  .timeline-item{width:50%;padding:32px 40px 32px 0;text-align:right}
  .timeline-item:nth-child(odd){margin-left:50%;padding:32px 0 32px 40px;text-align:left}
  .timeline-item:nth-child(odd) .timeline-dot{left:-8px}
  .timeline-item:nth-child(even) .timeline-dot{right:-8px}
  .timeline-item:nth-child(odd)::before{left:-6px}
  .timeline-item:nth-child(even)::before{right:-6px}
}

.timeline-dot{
  position:absolute;top:40px;width:12px;height:12px;
  background:var(--accent);border-radius:50%;
  border:3px solid var(--bg);
  box-shadow:var(--sh2);
}
.timeline-item:nth-child(1) .timeline-dot{left:18px}
@media(min-width:640px){
  .timeline-item:nth-child(odd) .timeline-dot{left:-8px}
  .timeline-item:nth-child(even) .timeline-dot{right:-8px}
}

.timeline-date{
  font-family:'DM Mono',monospace;font-size:11px;
  color:var(--accent);letter-spacing:.08em;text-transform:uppercase;
  margin-bottom:8px;
}
.timeline-title{
  font-family:'Newsreader',Georgia,serif;font-size:22px;
  font-weight:300;letter-spacing:-.02em;margin-bottom:8px;
}
.timeline-desc{
  font-size:14px;color:var(--ink2);font-weight:300;line-height:1.6;
}

.cta-section{
  padding:clamp(80px,10vw,140px) 0;
  text-align:center;
  position:relative;
}
.cta-section::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 80% 50% at 50% 100%,rgba(184,107,70,.05),transparent 50%);
  pointer-events:none;
}

.cta-inner{max-width:560px;margin:0 auto;position:relative;z-index:1}

.cta-section h2{
  font-family:'Newsreader',Georgia,serif;
  font-size:clamp(36px,6vw,64px);font-weight:300;letter-spacing:-.04em;
  line-height:1.05;color:var(--ink);margin-bottom:20px;
  opacity:0;
  transform:translateY(24px);
  animation:fade-up 0.8s var(--spring) 0.2s forwards;
}

.cta-section p{
  font-size:16px;color:var(--ink2);font-weight:300;
  margin-bottom:40px;line-height:1.7;
  opacity:0;
  transform:translateY(20px);
  animation:fade-up 0.8s var(--spring) 0.4s forwards;
}

.cta-links{
  display:flex;align-items:center;justify-content:center;gap:24px;flex-wrap:wrap;
  opacity:0;
  transform:translateY(16px);
  animation:fade-up 0.8s var(--spring) 0.6s forwards;
}

.cta-link{
  font-family:'DM Mono',monospace;font-size:13px;
  color:var(--ink2);display:inline-flex;align-items:center;gap:8px;
  padding:12px 24px;border:1px solid var(--line);
  border-radius:var(--pill);transition:all 0.25s var(--spring);
}
.cta-link:hover{
  background:var(--bg2);color:var(--ink);border-color:var(--ink3);
  transform:translateY(-2px);
}
.cta-link svg{opacity:.6;transition:opacity 0.2s ease}
.cta-link:hover svg{opacity:1}

.footer{
  padding:48px 0 32px;
  border-top:1px solid var(--line);
  text-align:center;
}
.footer p{
  font-family:'DM Mono',monospace;font-size:11px;
  color:var(--ink3);letter-spacing:.04em;
}
.footer a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}

.theme-toggle{
  position:fixed;bottom:24px;right:24px;
  width:44px;height:44px;border-radius:50%;
  background:var(--bg2);border:1px solid var(--line);
  color:var(--ink2);display:flex;
  align-items:center;justify-content:center;z-index:100;
  transition:all 0.25s var(--spring);
  box-shadow:var(--sh2);
}
.theme-toggle:hover{
  background:var(--bg3);color:var(--ink);border-color:var(--line2);
  transform:translateY(-2px);
}
.theme-toggle:focus-visible{
  outline:2px solid var(--accent);outline-offset:2px
}
.theme-toggle .icon-moon{display:none}
[data-theme="dark"] .theme-toggle .icon-sun{display:none}
[data-theme="dark"] .theme-toggle .icon-moon{display:block}

.scroll-fade{
  opacity:0;
  transform:translateY(30px);
  transition:opacity 0.8s var(--spring),transform 0.8s var(--spring);
}
.scroll-fade.visible{
  opacity:1;
  transform:translateY(0);
}
