:root{
  --bg:#0D0B09;
  --glow-x:50vw;
  --glow-y:40vh;
  --surface:#131210;
  --border:#252220;
  --text:#F5F4F2;
  --muted:#8A8480;
  --amber:#D4A96A;
  --sage:#2AB5C4;
  --green:#4EC87A;
  --radius-sm:4px;
  --radius-md:8px;
  --radius:12px;
  --radius-lg:16px;
  --content:900px;
  --prose:660px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:'Lato',ui-sans-serif,system-ui,sans-serif;
  background:
    radial-gradient(ellipse 65% 30% at 15%  8%, rgba(42,181,196,0.052) 0%, transparent 56%),
    radial-gradient(ellipse 50% 22% at 80% 28%, rgba(42,181,196,0.030) 0%, transparent 50%),
    radial-gradient(ellipse 55% 20% at 12% 50%, rgba(42,181,196,0.036) 0%, transparent 54%),
    radial-gradient(ellipse 48% 18% at 78% 68%, rgba(42,181,196,0.032) 0%, transparent 50%),
    radial-gradient(ellipse 52% 22% at 22% 88%, rgba(42,181,196,0.028) 0%, transparent 52%),
    var(--bg);
  color:var(--text);
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}
button{cursor:pointer;border:none;background:none;font-family:inherit;}

/* ── Grain ── */
body::before{
  content:'';
  position:fixed;
  inset:0;
  opacity:0.048;
  pointer-events:none;
  z-index:9998;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.72' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)'/%3E%3C/svg%3E");
  background-repeat:repeat;
  background-size:200px 200px;
}

/* ── Ambient glow — trails the cursor, never sticks to it ── */
body::after{
  content:'';
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:1;
  background:radial-gradient(620px circle at var(--glow-x) var(--glow-y),rgba(42,181,196,0.05),rgba(42,181,196,0.018) 42%,transparent 74%);
  opacity:0;
  transition:opacity 2.4s ease;
}
body.glow-on::after{opacity:1;}
@media(pointer:coarse),(prefers-reduced-motion:reduce){
  body::after{display:none;}
}

/* ── Site header ── */
.site-header{
  position:fixed;
  top:0;left:0;right:0;
  z-index:900;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 28px;
  height:52px;
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  background:rgba(13,11,9,0.8);
  border-bottom:1px solid rgba(37,34,32,0.6);
}
.site-header-name{
  display:flex;
  flex-direction:column;
  gap:3px;
  line-height:1;
  text-decoration:none;
  opacity:0;
  transform:translateX(-6px);
  transition:opacity 320ms ease, transform 320ms ease;
  pointer-events:none;
}
.site-header.nav-scrolled .site-header-name{
  opacity:1;
  transform:translateX(0);
  pointer-events:auto;
}
.site-header-name:hover{opacity:0.65 !important;}
.logo-name{
  font-family:'DM Serif Display',serif;
  font-size:19px;
  font-weight:400;
  font-style:normal;
  color:var(--text);
  letter-spacing:-0.01em;
  line-height:1;
}
.logo-role{
  font-family:'DM Mono',monospace;
  font-size:8px;
  font-weight:400;
  color:var(--sage);
  letter-spacing:0.18em;
  text-transform:uppercase;
  line-height:1;
}
.site-header-right{
  display:flex;
  align-items:center;
  gap:12px;
}
.header-social{
  display:flex;
  align-items:center;
  gap:10px;
  margin-right:4px;
}
.header-social-link{
  display:flex;
  align-items:center;
  color:var(--muted);
  opacity:0.38;
  transition:opacity 500ms ease, color 500ms ease;
  text-decoration:none;
}
.header-social-link:hover{
  opacity:1;
  color:var(--sage);
}
.header-social-sep{
  width:1px;
  height:12px;
  background:var(--border);
  margin-right:4px;
}
@media(max-width:640px){.header-social{display:none;}.site-header-section{display:none;}.nav-now-link{display:none !important;}}
/* Hidden in the hero so the opening availability dot is the only one on screen;
   appears with the rest of the header chrome on scroll (inner pages are always nav-scrolled) */
.nav-now-link{
  display:flex;
  align-items:center;
  gap:7px;
  text-decoration:none;
  opacity:0;
  pointer-events:none;
  transition:opacity 320ms ease;
}
.site-header.nav-scrolled .nav-now-link{opacity:0.8;pointer-events:auto;}
.site-header.nav-scrolled .nav-now-link:hover{opacity:1;}
.site-header-section{
  font-family:'DM Mono',monospace;
  font-size:10px;
  color:var(--muted);
  letter-spacing:0.1em;
  opacity:0;
  transition:opacity 300ms;
}
.site-header-section.visible{opacity:1;}
.site-header-right .availability-dot{
  position:relative;
  width:7px;height:7px;
  border-radius:50%;
  background:var(--green);
  flex-shrink:0;
}
.site-header-right .availability-dot::after{
  content:'';
  position:absolute;
  inset:-3px;
  border-radius:50%;
  border:1.5px solid var(--green);
  animation:ripple 2.4s ease-out infinite;
}
.site-header-right .availability-dot.occupied{background:var(--amber);}
.site-header-right .availability-dot.occupied::after{border-color:var(--amber);}
.site-header-right span:last-child{
  font-size:12px;
  color:var(--green);
  letter-spacing:0.04em;
  font-family:'DM Mono',monospace;
}

/* ── Reveal ── */
.reveal{
  opacity:0;
  transform:translateY(28px);
  transition:opacity 600ms ease-out,transform 600ms ease-out;
}
.reveal.visible{opacity:1;transform:translateY(0);}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto;}
  *,*::before,*::after{
    animation-duration:0.01ms !important;
    animation-delay:0s !important;
    animation-iteration-count:1 !important;
    transition-duration:0.01ms !important;
  }
  .reveal{opacity:1;transform:none;}
}

@keyframes ripple{
  0%{transform:scale(1);opacity:0.7;}
  100%{transform:scale(2.8);opacity:0;}
}

#fc-wrap{position:fixed;bottom:28px;left:28px;z-index:800;opacity:0;transition:opacity 500ms ease;pointer-events:none;}
#fc-wrap.fc-visible{opacity:1;pointer-events:auto;}
.fc-btn{width:36px;height:36px;border-radius:50%;background:var(--surface,#131210);border:1px solid rgba(42,181,196,0.45);display:flex;align-items:center;justify-content:center;color:var(--sage,#2AB5C4);cursor:pointer;transition:all 200ms ease;position:relative;z-index:2;box-shadow:0 0 10px rgba(42,181,196,0.2),0 0 20px rgba(42,181,196,0.08);}
.fc-btn:hover,.fc-btn:focus{color:var(--sage,#2AB5C4);border-color:rgba(42,181,196,0.4);outline:none;}
#fc-wrap:hover .fc-btn{color:var(--sage,#2AB5C4);border-color:rgba(42,181,196,0.35);}
.fc-nav{position:absolute;bottom:46px;left:0;background:var(--surface,#131210);border:1px solid var(--border,#252220);border-radius:10px;padding:6px;display:flex;flex-direction:column;gap:2px;min-width:148px;opacity:0;transform:translateY(6px);pointer-events:none;transition:opacity 180ms ease,transform 180ms ease;box-shadow:0 12px 40px rgba(0,0,0,0.45);}
#fc-wrap:hover .fc-nav,#fc-wrap.fc-open .fc-nav{opacity:1;transform:translateY(0);pointer-events:auto;}
.fc-link,.fc-link-btn{display:block;padding:8px 12px;font-family:'DM Mono',monospace;font-size:10px;letter-spacing:0.08em;text-transform:uppercase;color:var(--muted,#8A8480);text-decoration:none;border-radius:6px;background:none;border:none;width:100%;text-align:left;cursor:pointer;transition:color 140ms,background 140ms;}
.fc-link:hover,.fc-link-btn:hover{color:var(--sage,#2AB5C4);background:rgba(42,181,196,0.06);}
/* ── Work With Me Modal ── */
#wwm-overlay{
  position:fixed;inset:0;z-index:2000;
  background:rgba(13,11,9,0.88);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  display:flex;align-items:center;justify-content:center;
  padding:24px;opacity:0;pointer-events:none;
  transition:opacity 260ms ease;
}
#wwm-overlay.open{opacity:1;pointer-events:auto;}
#wwm-modal{
  background:var(--surface);border:1px solid var(--border);
  border-radius:16px;width:100%;max-width:420px;
  padding:36px;position:relative;
  transform:translateY(18px);
  transition:transform 320ms cubic-bezier(0.22,1,0.36,1);
  box-shadow:0 32px 80px rgba(0,0,0,0.55);
}
#wwm-overlay.open #wwm-modal{transform:translateY(0);}
.wwm-close{
  position:absolute;top:18px;right:18px;
  width:30px;height:30px;background:none;
  border:1px solid var(--border);border-radius:50%;
  color:var(--muted);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  font-size:13px;padding:0;transition:border-color 180ms,color 180ms;
}
.wwm-close:hover{border-color:rgba(42,181,196,0.4);color:var(--sage);}
.wwm-eyebrow{display:none;}
.wwm-heading{display:none;}
.wwm-sub{display:none;}
.wwm-field{margin-bottom:14px;}
.wwm-field label{
  display:block;font-family:'DM Mono',monospace;
  font-size:9px;letter-spacing:0.12em;text-transform:uppercase;
  color:var(--muted);margin-bottom:6px;
}
.wwm-optional{opacity:0.5;font-size:8px;}
.wwm-field input,.wwm-field textarea{
  width:100%;background:rgba(255,255,255,0.04);
  border:1px solid var(--border);border-radius:8px;
  padding:10px 14px;color:var(--text);
  font-family:'Lato',sans-serif;font-size:14px;
  outline:none;transition:border-color 180ms;resize:none;
  box-sizing:border-box;
}
.wwm-field input::placeholder,.wwm-field textarea::placeholder{color:rgba(138,132,128,0.5);}
.wwm-field input:focus,.wwm-field textarea:focus{border-color:rgba(42,181,196,0.4);}
.wwm-field textarea{min-height:110px;}
.wwm-file-zone{
  border:1px dashed var(--border);border-radius:8px;
  padding:13px 14px;cursor:pointer;position:relative;
  transition:border-color 200ms,background 200ms,box-shadow 200ms;
  min-height:48px;display:flex;align-items:center;
  box-shadow:0 0 0 0 rgba(42,181,196,0);
}
.wwm-file-zone:hover{
  border-color:rgba(42,181,196,0.45);
  background:rgba(42,181,196,0.03);
}
.wwm-file-zone.drag-over{
  border-color:rgba(42,181,196,0.7);
  background:rgba(42,181,196,0.07);
  box-shadow:0 0 0 3px rgba(42,181,196,0.12);
}
.wwm-file-zone input[type=file]{
  position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%;font-size:0;
}
.wwm-file-hint{
  font-family:'DM Mono',monospace;font-size:10px;
  letter-spacing:0.08em;color:var(--muted);opacity:0.45;
  width:100%;text-align:center;pointer-events:none;
  transition:opacity 160ms;
}
.wwm-file-zone:hover .wwm-file-hint{opacity:0.7;}
.wwm-file-info{
  display:flex;align-items:center;gap:10px;width:100%;
  pointer-events:none;
  opacity:0;transition:opacity 200ms;
}
.wwm-file-zone.has-file .wwm-file-hint{opacity:0;pointer-events:none;position:absolute;}
.wwm-file-zone.has-file .wwm-file-info{opacity:1;}
@keyframes wwm-spin{to{transform:rotate(360deg);}}
.wwm-file-zone.uploading .wwm-file-status{
  display:inline-block;animation:wwm-spin 0.8s linear infinite;
}
.wwm-file-zone.upload-done{border-style:solid;border-color:rgba(42,181,196,0.4);}
.wwm-file-zone.upload-error{border-style:solid;border-color:rgba(224,112,112,0.4);}
.wwm-file-name-text{
  font-family:'DM Mono',monospace;font-size:10px;
  color:var(--text);flex:1;overflow:hidden;
  text-overflow:ellipsis;white-space:nowrap;
}
.wwm-file-size-text{
  font-family:'DM Mono',monospace;font-size:9px;
  color:var(--muted);opacity:0.6;flex-shrink:0;
}
.wwm-file-status{font-family:'DM Mono',monospace;font-size:12px;flex-shrink:0;}
.wwm-file-remove{
  background:none;border:1px solid var(--border);border-radius:50%;
  width:18px;height:18px;color:var(--muted);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  font-size:10px;padding:0;flex-shrink:0;pointer-events:all;
  transition:border-color 180ms,color 180ms;line-height:1;
}
.wwm-file-remove:hover{border-color:rgba(224,112,112,0.5);color:#e07070;}
.wwm-error{
  font-family:'DM Mono',monospace;font-size:10px;
  color:#e07070;margin-bottom:12px;display:none;
}
.wwm-submit{
  width:100%;margin-top:6px;
  background:var(--sage);border:none;border-radius:8px;
  padding:13px;color:#0D0B09;
  font-family:'DM Mono',monospace;font-size:11px;
  letter-spacing:0.1em;text-transform:uppercase;
  cursor:pointer;transition:opacity 180ms;
}
.wwm-submit:hover{opacity:0.85;}
.wwm-submit:disabled{opacity:0.45;cursor:not-allowed;}
.wwm-success{display:none;text-align:center;padding:24px 0;}
.wwm-success-icon{
  font-size:32px;color:var(--sage);margin-bottom:14px;
}
.wwm-success-text{
  font-family:'DM Serif Display',serif;font-size:22px;
  color:var(--text);margin-bottom:8px;
}
.wwm-success-sub{font-size:13px;color:var(--muted);}
@media(max-width:480px){
  #wwm-modal{padding:28px 22px;}
  .wwm-heading{font-size:26px;}
}
