*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}

:root{
  --bg:   #e9e7e1;
  --ink:  #1a1816;
  --mid:  #7a7670;
  --lt:   #c0bbb5;
  --white:#ffffff;
  --serif:'EB Garamond',Georgia,serif;
  --sans: 'Helvetica Neue',Helvetica,Arial,sans-serif;
}

html{ scroll-behavior:smooth; }

body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-size:13px;
  font-weight:300;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  cursor:none;
}

/* ── CURSOR ── */
#cur,#cur-ring{
  position:fixed;pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);
  transition-property:width,height,opacity;
  transition-duration:.2s;
}
#cur{width:5px;height:5px;border-radius:50%;background:var(--ink);}
#cur-ring{
  width:28px;height:28px;border-radius:50%;z-index:9998;
  border:1px solid rgba(26,24,22,.28);
  transition:width .35s cubic-bezier(.16,1,.3,1),height .35s cubic-bezier(.16,1,.3,1);
}
body.hov #cur{opacity:0;}
body.hov #cur-ring{width:46px;height:46px;}

/* ── GRAIN ── */
body::after{
  content:'';position:fixed;inset:0;z-index:8000;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity:.028;
}

/* ── LOADER ── */
#loader{
  position:fixed;inset:0;z-index:7000;
  background:var(--bg);
  display:flex;align-items:center;justify-content:center;
  transition:transform .6s cubic-bezier(.76,0,.24,1);
}
#loader.out{transform:translateY(-100%);}
#l-name{
  font-family:var(--serif);font-size:14px;letter-spacing:.04em;
  opacity:0;animation:fade .5s ease .1s forwards;
}
#l-bar{position:absolute;bottom:0;left:0;height:1px;width:0;background:var(--ink);
  animation:bar 1s cubic-bezier(.4,0,.2,1) .15s forwards;}
@keyframes fade{to{opacity:1;}}
@keyframes bar{to{width:100%;}}

/* ── NAV ── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:500;
  height:44px;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 32px;
  background:var(--bg);
  transition:background .3s ease;
}
nav.white-bg{background:var(--white);}

.nav-logo{
  font-size:13px;font-weight:400;letter-spacing:.01em;
  color:var(--ink);text-decoration:none;cursor:none;
  transition:opacity .2s;
}
.nav-logo:hover{opacity:.55;}

.nav-links{display:flex;gap:26px;list-style:none;align-items:center;}
.nav-links a{
  font-size:12px;font-weight:400;letter-spacing:.01em;
  color:var(--ink);text-decoration:none;cursor:none;
  opacity:.55;
  transition:opacity .2s;
}
.nav-links a:hover,.nav-links a.on{opacity:1;}
.nav-links a.on{border-bottom:1px solid var(--ink);}

/* ── PAGE WRAPPER ── */
.page{padding-top:44px;min-height:100vh;}
