/* ============================================================
   WINE GLASS — shared chrome (nav + footer)
   ============================================================ */

/* ---------- NAV ---------- */
.site-nav{
  position:absolute;top:0;left:0;right:0;z-index:40;
  display:flex;justify-content:space-between;align-items:center;
  padding:calc(1.6rem + env(safe-area-inset-top)) var(--gutter);
}
.site-nav .sig{display:inline-flex;line-height:0;}
.site-nav .sig img{height:72px;width:auto;
  filter:drop-shadow(0 0 1px rgba(247,210,220,0.9)) drop-shadow(0 0 7px rgba(247,210,220,0.55)) drop-shadow(0 0 18px rgba(240,192,204,0.35));
  transition:transform var(--dur-fast) var(--ease-out-back),filter .3s ease;}
.site-nav .sig:hover img{transform:rotate(-3deg) scale(1.04);
  filter:drop-shadow(0 0 1px rgba(255,236,242,1)) drop-shadow(0 0 9px rgba(247,210,220,0.8)) drop-shadow(0 0 22px rgba(240,192,204,0.5));}

.site-nav ul{display:flex;gap:2rem;list-style:none;align-items:center;}
.site-nav a.nav-link{
  font-family:var(--font-display);
  font-size:0.72rem;letter-spacing:0.14em;text-transform:uppercase;font-weight:600;
  color:var(--fg-dim);
  position:relative;padding-block:0.3rem;
  transition:color var(--dur-fast) ease;
}
.site-nav a.nav-link::after{
  content:"";position:absolute;left:0;bottom:0;height:1px;width:0;
  background:var(--accent-bright);transition:width var(--dur-mid) var(--ease-out-expo);
}
.site-nav a.nav-link:hover{color:var(--accent-bright);}
.site-nav a.nav-link:hover::after{width:100%;}
.site-nav a.nav-link.is-current{color:var(--accent-bright);}
.site-nav a.nav-link.is-current::after{width:100%;}

@media(max-width:880px){
  /* logo left, links wrap in compact rows on the right — header stays ~100px
     tall so a wrapped CONTACT can never spill onto page headlines */
  .site-nav{align-items:center;gap:1rem;padding:calc(1rem + env(safe-area-inset-top)) var(--gutter);}
  .site-nav .sig img{height:44px;}
  .site-nav ul{justify-content:flex-end;gap:0.45rem 1rem;flex-wrap:wrap;}
  .site-nav a.nav-link{font-size:0.58rem;letter-spacing:0.1em;padding-block:0.3rem;}
}

/* ---------- FOOTER ---------- */
.site-footer{
  position:relative;
  background:var(--wine-950);
  border-top:1px solid var(--hairline);
  padding:var(--sp-6) var(--gutter) calc(var(--sp-4) + env(safe-area-inset-bottom));
  overflow:hidden;
}
.footer-inner{max-width:var(--measure);margin-inline:auto;position:relative;z-index:2;}
.footer-top{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;margin-bottom:var(--sp-5);}
.footer-cta-line{
  font-family:var(--font-display);font-weight:700;text-transform:lowercase;letter-spacing:-0.01em;
  font-size:clamp(1.5rem,3.2vw,2.6rem);line-height:1.2;color:var(--fg);max-width:18ch;
}
.footer-cta-line em{font-style:normal;background:var(--grad-head-soft);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;}
.footer-links{display:flex;gap:1.6rem;flex-wrap:wrap;}
.footer-links a{
  font-family:var(--font-display);font-weight:600;font-size:0.72rem;letter-spacing:0.12em;text-transform:uppercase;
  color:var(--fg-dim);transition:color var(--dur-fast) ease;
}
.footer-links a:hover{color:var(--accent-bright);}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;
  padding-top:var(--sp-3);border-top:1px solid var(--hairline);
  font-family:var(--font-ui);font-size:0.68rem;letter-spacing:0.08em;color:var(--fg-faint);
}
@media(max-width:880px){
  .footer-top{flex-direction:column;align-items:flex-start;gap:1.6rem;}
  .footer-bottom{flex-direction:column;align-items:flex-start;text-align:left;}
}

/* ============================================================
   BRANDED LOADER — typographic + math curve
   ============================================================ */
.loader{
  position:fixed;inset:0;z-index:9999;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:radial-gradient(120% 90% at 50% 45%,#3a1828 0%,#1a0710 55%,#120308 100%);
  transition:opacity 0.9s var(--ease-out-expo),visibility 0.9s var(--ease-out-expo);
}
.loader.is-done{opacity:0;visibility:hidden;pointer-events:none;}
.loader-stage{position:relative;width:min(86vw,560px);height:280px;display:flex;align-items:center;justify-content:center;}
/* the morphing jelly that coalesces behind the name */
.loader-blob{
  position:absolute;width:200px;height:200px;
  background:var(--glass-iris),radial-gradient(120% 120% at 70% 80%,rgba(122,40,64,0.6),rgba(42,15,28,0.3) 70%);
  background-blend-mode:screen,normal;
  border-radius:42% 58% 60% 40% / 48% 42% 58% 52%;
  box-shadow:inset 0 8px 30px rgba(255,245,240,0.4),inset 0 -18px 46px rgba(92,36,54,0.6),0 30px 80px rgba(20,4,9,0.5);
  filter:saturate(1.2);
  animation:loader-blob-in 1.3s var(--ease-out-expo) forwards,jelly-morph 14s var(--ease-in-out) infinite 1.3s;
  opacity:0;transform:scale(0.2);
}
@keyframes loader-blob-in{to{opacity:0.85;transform:scale(1);}}

.loader-curve{position:absolute;width:100%;height:100%;overflow:visible;z-index:2;}

/* coquette bow above the name */
.loader-bow{
  position:absolute;top:-2%;left:50%;width:150px;height:auto;z-index:4;
  transform:translateX(-50%);transform-origin:center bottom;
  opacity:0;
  animation:bow-in 0.9s var(--ease-out-back) forwards 0.35s, bow-sway 5s var(--ease-in-out) infinite 1.3s;
  filter:drop-shadow(0 12px 24px rgba(122,40,64,0.55));
}
@keyframes bow-in{
  0%{opacity:0;transform:translateX(-50%) scale(0.3) rotate(-14deg);}
  100%{opacity:1;transform:translateX(-50%) scale(1) rotate(0deg);}
}
@keyframes bow-sway{
  0%,100%{transform:translateX(-50%) rotate(0deg);}
  50%{transform:translateX(-50%) rotate(3.5deg);}
}
.loader-curve path{
  fill:none;stroke:rgba(240,192,204,0.5);stroke-width:1.4;
  stroke-dasharray:1;stroke-dashoffset:1;
  animation:draw-curve 2s var(--ease-in-out) forwards;
}
@keyframes draw-curve{to{stroke-dashoffset:0;}}

.loader-name{
  position:relative;z-index:3;text-align:center;
  font-family:var(--font-display);font-style:normal;font-weight:800;
  font-size:clamp(2rem,6.4vw,3.3rem);line-height:1;
  color:transparent;
}
.loader-name .lw{display:inline-block;}
.loader-name .ch{
  display:inline-block;
  background:var(--grad-head);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  opacity:0;transform:translateY(0.5em);
  animation:char-in 0.7s var(--ease-out-expo) forwards;
}
@keyframes char-in{to{opacity:1;transform:none;}}

.loader-enter{
  position:absolute;bottom:8%;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:0.8rem;
  opacity:0;animation:enter-in 0.6s ease forwards 2.4s;
}
.loader-enter .hint{
  font-family:var(--font-ui);font-size:0.66rem;letter-spacing:0.28em;text-transform:uppercase;
  color:var(--fg-faint);
}
.loader-enter .enter-btn{
  font-family:var(--font-display);font-size:0.74rem;letter-spacing:0.08em;text-transform:lowercase;font-weight:600;
  color:var(--accent-bright);
  padding:0.8rem 2rem;border-radius:var(--r-pill);
  border:1px solid var(--hairline-strong);background:rgba(240,192,204,0.06);
  display:inline-flex;align-items:center;gap:0.6rem;
  transition:all var(--dur-fast) var(--ease-out-expo);
}
.loader-enter .enter-btn:hover{background:rgba(240,192,204,0.14);border-color:rgba(240,192,204,0.7);transform:translateY(-2px);}
.loader-enter .enter-btn .eq{display:inline-flex;gap:3px;align-items:flex-end;height:12px;}
.loader-enter .enter-btn .eq span{width:2px;background:var(--accent-bright);border-radius:2px;animation:eq 0.9s var(--ease-in-out) infinite;}
.loader-enter .enter-btn .eq span:nth-child(1){height:6px;animation-delay:0s;}
.loader-enter .enter-btn .eq span:nth-child(2){height:12px;animation-delay:0.15s;}
.loader-enter .enter-btn .eq span:nth-child(3){height:8px;animation-delay:0.3s;}
@keyframes eq{0%,100%{transform:scaleY(0.5);}50%{transform:scaleY(1);}}
@keyframes enter-in{to{opacity:1;}}

/* tech-stack credit line */
.footer-tech{font-family:ui-monospace,'SFMono-Regular',Menlo,Consolas,monospace;font-size:0.64rem;letter-spacing:0.14em;color:var(--fg-faint);display:flex;align-items:center;gap:0.55rem;flex-wrap:wrap;margin-bottom:1rem;}
.footer-tech .sl{color:var(--accent);opacity:0.8;}
.footer-tech .dt{width:5px;height:5px;border-radius:50%;background:var(--accent);box-shadow:0 0 6px rgba(196,116,139,0.6);flex:none;}
/* tech-stack credit terms — analogous rose → fuchsia → violet → pink arc (same family as the contact aurora) */
.footer-tech .ftk{font-weight:600;text-shadow:0 0 7px color-mix(in oklab, currentColor 42%, transparent);transition:filter .3s ease;}
.footer-tech:hover .ftk{filter:brightness(1.12);}
.footer-tech .ftk-rose{color:hsl(343 72% 73%);}
.footer-tech .ftk-fuchsia{color:hsl(322 82% 70%);}
.footer-tech .ftk-violet{color:hsl(281 66% 76%);}
.footer-tech .ftk-pink{color:hsl(334 86% 76%);}
.footer-tech .ftk-purple{color:hsl(266 72% 76%);}
