/* ==================================================================
   Tristan Hanford — Site Styles v3.3 (Home + About)
   - Connections bar: wider span, icons, larger text, positioned lower
   - Explore panel: feathered gradient to taupe, more vertical spacing
   - Explore buttons: soft fade on hover (light slate), text → white
   - Typewriter: caret follows text; soft accent color
   - About header: full-width slate banner, white text
   - About intro: larger subtitle, better spacing & CTA offset
   ================================================================== */

/* -------------------- Design Tokens -------------------- */
:root{
  --paper:#ffffff;
  --taupe:#e4ddcc;
  --slate:#2b2f33;          /* text/body */
  --slate-strong:#1f2327;   /* headings */
  --muted:#707780;
  --line:rgba(15,17,19,.12);
  --focus:#0a6cff;
  --accent-soft:#b45858;    /* soft red accent for typed words */

  --radius:14px; --radius-lg:22px; --radius-xl:28px;
  --shadow-1:0 10px 28px rgba(0,0,0,.08);
  --shadow-2:0 18px 46px rgba(0,0,0,.16);

  --maxw:1200px; --nav-h:72px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;color:var(--slate);
  background-color:var(--taupe);
  background-image:radial-gradient(circle at 12% 18%, rgba(255,255,255,.65), rgba(255,255,255,0) 48%),
                   radial-gradient(circle at 82% 12%, rgba(214,205,187,.65), rgba(214,205,187,0) 52%),
                   linear-gradient(180deg, rgba(255,255,255,.9) 0%, rgba(236,229,216,.65) 44%, rgba(228,221,204,.9) 100%);
  background-attachment:fixed;
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
   min-height:100%;
  position:relative;
}

body::before,
body::after{
  content:"";
  position:fixed;
  inset:-30vh -30vw;
  pointer-events:none;
  z-index:-2;
  transition:opacity .6s ease;
}

body::before{
  background:radial-gradient(circle at 30% 30%, rgba(255,255,255,.38), rgba(255,255,255,0) 60%),
             radial-gradient(circle at 70% 60%, rgba(214,205,187,.35), rgba(214,205,187,0) 62%);
  opacity:.7;
}

body::after{
  z-index:-3;
  inset:-60vh -40vw;
  background:linear-gradient(120deg, rgba(255,255,255,.18) 0%, rgba(196,188,171,.12) 48%, rgba(31,35,39,.08) 100%);
  mix-blend-mode:soft-light;
  opacity:.55;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}
h1,h2,h3{margin:0 0 .5rem;line-height:1.15}

/* -------------------- Reveal animations -------------------- */
body.has-reveal .reveal-item{
  opacity:0;
  transform:translate3d(0,32px,0);
  transition:opacity .6s ease, transform .6s ease;
  transition-delay:var(--reveal-delay,0ms);
  will-change:opacity,transform;
}

body.has-reveal .reveal-item.is-visible{
  opacity:1;
  transform:translate3d(0,0,0);
}

@media (prefers-reduced-motion:reduce){
  body.has-reveal .reveal-item{opacity:1 !important;transform:none !important;transition:none !important}
}

/* -------------------- Buttons -------------------- */
.btn-primary,.btn-outline{
  position:relative;display:inline-flex;align-items:center;gap:10px;cursor:pointer;
  border-radius:999px;font-weight:800;letter-spacing:.03rem;padding:12px 18px;
  transition:transform .18s ease,box-shadow .18s ease,filter .18s ease;
}
.btn-primary{background:var(--paper);color:var(--slate);border:1px solid rgba(43,47,51,.18);box-shadow:var(--shadow-1)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:var(--shadow-2);filter:brightness(1.02)}
.btn-outline{background:transparent;color:var(--slate);border:2px solid rgba(43,47,51,.6)}
.btn-outline:hover{transform:translateY(-1px);box-shadow:var(--shadow-1)}
.btn-primary.is-taupe{background:var(--taupe);border-color:rgba(43,47,51,.22)}
.btn-primary.is-taupe:hover{filter:brightness(1.02)}

/* Keep the radiating hover ONLY for generic buttons (not panel links) */
.btn-primary::before,.btn-primary::after{
  content:"";position:absolute;inset:0;pointer-events:none;border-radius:12px;opacity:0;
  border:2px solid rgba(43,47,51,.18);transform:scale(.9);
}
.btn-primary:hover::before{animation:burst 900ms ease-out forwards}
.btn-primary:hover::after{animation:burst 1200ms 90ms ease-out forwards}
@keyframes burst{0%{opacity:0;transform:scale(.9)}35%{opacity:.65}100%{opacity:0;transform:scale(1.25)}}

:focus-visible{outline:3px solid var(--focus);outline-offset:2px}

/* -------------------- Navbar (fades in; JS animates opacity) -------------------- */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:60;
  opacity:0;pointer-events:none;backdrop-filter:saturate(1.05) blur(8px);
}
.navbar::before{content:"";position:absolute;inset:0;background:rgba(255,255,255,.9);border-bottom:1px solid var(--line)}
.navbar.nav-active{pointer-events:auto}
.nav-inner{position:relative;height:var(--nav-h);display:grid;grid-template-columns:1fr auto 1fr;align-items:center}
.nav-title{justify-self:start;font-weight:800;letter-spacing:.08em;text-transform:uppercase;padding-left:8px}
.nav-links{list-style:none;display:flex;gap:18px;margin:0;padding:0}
.nav-links a{padding:10px 12px;border-radius:999px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;font-size:.9rem}
.nav-links a[aria-current="page"]{background:var(--paper);box-shadow:var(--shadow-1)}
.menu-btn{justify-self:end;background:transparent;border:0;font-size:1.6rem;padding:8px;display:none}
.drawer{position:fixed;inset:var(--nav-h) 0 auto 0;background:#fff;display:none;border-top:1px solid var(--line);box-shadow:0 10px 24px rgba(0,0,0,.08)}
.drawer.open{display:block}
.drawer ul{list-style:none;margin:0;padding:12px}
.drawer li{border-bottom:1px solid var(--line)}
.drawer a{display:block;padding:14px 8px;font-weight:800;letter-spacing:.06em;text-transform:uppercase}
@media (max-width:920px){.nav-inner{grid-template-columns:auto 1fr auto}.nav-links{display:none}.menu-btn{display:block}}

/* -------------------- Hero -------------------- */
.hero{position:relative;min-height:100dvh;display:grid;align-items:center;padding:60px 0 80px}
.hero-bg{position:absolute;inset:0;z-index:-1;overflow:hidden}
.magnetic-field{position:absolute;inset:0;width:100%;height:100%;display:block}

/* Connections bar (wider span, icons, bigger text, positioned lower) */
.hero-connections{
  position:absolute;left:50%;transform:translateX(-50%);top:clamp(56px,17vh,190px);
  display:flex;align-items:center;gap:40px;color:#5b6168;
}
.hero-connections__line{
  display:block;height:1px;width:min(34vw,380px);background:rgba(43,47,51,.25);pointer-events:none;
}
.hero-connections a{font-weight:800;font-size:1.06rem;display:flex;flex-direction:column;align-items:center;gap:6px}
.hero-connections .dot{opacity:.6}
/* Icons via data-URI SVGs */
.hero-connections a::before{content:"";display:block;width:22px;height:22px;opacity:.9}
.hero-connections a[href*="linkedin."]::before{
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24' fill='none' stroke='%232b2f33' stroke-width='1.8'><rect x='3' y='3' width='18' height='18' rx='2'/><path d='M8 11v6M8 7.5v.5M12 17v-6a3 3 0 0 1 6 0v6'/></svg>") center/contain no-repeat;
}
.hero-connections a[href^="mailto:"]::before{
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24' fill='none' stroke='%232b2f33' stroke-width='1.8'><rect x='3' y='5' width='18' height='14' rx='2'/><path d='M3 7l9 6 9-6'/></svg>") center/contain no-repeat;
}
.hero-connections a[href*="instagram."]::before{
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24' fill='none' stroke='%232b2f33' stroke-width='1.8'><rect x='3' y='3' width='18' height='18' rx='4'/><circle cx='12' cy='12' r='3.5'/><circle cx='17' cy='7' r='1'/></svg>") center/contain no-repeat;
}

.hero-inner{display:grid;grid-template-columns:1.05fr .95fr;gap:32px;align-items:center}
@media (max-width:980px){.hero-inner{grid-template-columns:1fr}}

@media (max-width:1360px), (max-height:820px){
  .hero{align-items:flex-start;padding:calc(var(--nav-h) + 100px) 0 80px;}
  .hero-connections{
    position:relative;
    top:auto;
    left:auto;
    transform:none;
    margin:0 auto 36px;
    flex-wrap:wrap;
    justify-content:center;
    padding:0 clamp(12px, 4vw, 32px);
  }
  .hero-connections__line{display:none;}
  .hero-inner{margin-top:0;}
}

@media (max-width:980px){
  .hero{padding:calc(var(--nav-h) + 120px) 0 72px;}
  .hero-connections{gap:28px;}
}

@media (max-width:640px){
  .hero-connections{flex-direction:column;gap:18px;align-items:center;}
  .hero-cta{flex-direction:column;align-items:stretch;}
}

.eyebrow{letter-spacing:.26em;text-transform:uppercase;font-weight:800;font-size:.86rem;color:#4d545c}
.hero-title{font-family:'Playfair Display',Georgia,serif;font-weight:700;font-size:clamp(2.6rem,6vw,4.6rem)}
.typed-wrap{margin-top:14px;font-weight:800;font-size:clamp(1.25rem,3.2vw,1.85rem)}
/* Typed words: soft accent + blinking caret, caret follows text */
.typed{
  color:var(--accent-soft);display:inline-block;white-space:nowrap;
  border-right:2px solid rgba(31,35,39,.95);padding-right:8px;animation:blink .9s steps(1) infinite;
}
@keyframes blink{50%{border-color:transparent}}
.hero-cta{
  margin-top:32px;
  display:flex;
  flex-wrap:wrap;
  gap:16px;
}

/* -------------------- Quick-nav panel (Explore) -------------------- */
.hero-col--panel{display:flex;justify-content:center}
.panel{
  position:relative;width:min(560px,100%);border-radius:var(--radius-xl);
  border:1px solid rgba(43,47,51,.14);
  background:linear-gradient(180deg, rgba(255,255,255,.94) 0%, rgba(255,255,255,.7) 55%, rgba(255,255,255,.4) 100%);
  box-shadow:0 24px 48px rgba(0,0,0,.12);padding:26px 20px;overflow:hidden; /* clip any effects */
  backdrop-filter:blur(14px) saturate(1.08);
}
.panel::after{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;box-shadow:inset 0 1px 0 rgba(255,255,255,.35)}
.panel-title{
  margin:0 0 12px;text-align:center;font-weight:900;letter-spacing:.08em;text-transform:uppercase;
  font-size:clamp(1.15rem,2.4vw,1.5rem);
}
/* More vertical spacing between buttons */
.panel-links{display:grid;grid-template-columns:1fr;gap:28px;margin-top:10px}

/* Explore buttons: subtle fade + white text on hover */
.panel-link{
  position:relative;
  display:block;
  text-align:center;
  padding:16px 18px;
  border-radius:999px;
  background: rgba(255,255,255,.86);
  border:1px solid rgba(43,47,51,.18);
  font-weight:800;
  box-shadow: var(--shadow-1);
  transition: background-color .22s ease, color .18s ease, transform .18s ease, box-shadow .18s ease;
}
.panel-link:hover,
.panel-link:focus-visible{
  background: rgba(43,47,51,.08); /* very light slate */
  color: #fff;
  transform: translateY(-1px);
  box-shadow: var(--shadow-2);
}
/* Disable old refract filter for panel links */
.refract-armed .panel-link:hover{ filter:none }
.refract-filter{position:absolute;width:0;height:0}

/* -------------------- About -------------------- */
.section.about{background:var(--paper);border-top:1px solid var(--line);scroll-margin-top:var(--nav-h)}
/* Full-width slate banner for About heading */
.section-band{position:relative;inset:0;background:var(--slate-strong);color:#fff}
.section-band .band-inner{
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 18px 24px;
  padding-left: max(8vw, 36px); /* pushes the title right */
}
.section-band h2{
  margin: 0;
  font-weight: 900;
  letter-spacing: .06em;
  font-size: clamp(2rem, 4.4vw, 3rem); /* larger banner title */
  color: #fff;
}

/* Top row: portrait + blurb */
.about-grid{display:grid;grid-template-columns:0.9fr 1.1fr;gap:34px;align-items:start;padding:48px 0 68px}
@media (max-width:980px){.about-grid{grid-template-columns:1fr}}
.portrait{max-width:340px;border-radius:28px;overflow:hidden;background:var(--paper);box-shadow:var(--shadow-1);border:1px solid var(--line)}
.portrait img{width:100%;height:auto;display:block}
@media (max-width:980px){.portrait{max-width:320px}}
@media (max-width:520px){.portrait{max-width:280px}}

.about-body{ padding-top:10px; } /* aligns text block with top of photo */
.about-subtitle{
  margin:0 0 12px; font-weight:900; letter-spacing:.06em; text-transform:uppercase;
  color:var(--slate-strong); font-size:clamp(1.05rem,2vw,1.28rem);
}
.about-blurb{ margin:0 0 14px; color:var(--slate); }

/* Buttons below blurb */
.about-cta{
  display:flex;gap:12px;flex-wrap:wrap;margin-top:36px;
}

/* Lower row: workflow (left) + bubble panel (right) */
.about-lower{
  display:grid; grid-template-columns:1.1fr .9fr; gap:28px; align-items:start; padding:8px 0 8px;
}
@media (max-width:980px){ .about-lower{ grid-template-columns:1fr; } }

.block-title{
  margin:0 0 12px; font-weight:900; letter-spacing:.06em; text-transform:uppercase;
  font-size:clamp(1rem,1.9vw,1.2rem); color:var(--slate-strong);
}

/* Workflow cards */
.workflow-steps{
  margin:0; padding:8px 0 0 0; list-style:none; position:relative;
}
.workflow-steps::before{
  content:""; position:absolute; left:16px; top:0; bottom:0; width:2px; background:rgba(43,47,51,.18);
  box-shadow:0 0 12px rgba(43,47,51,.1);
}
.step{
  position:relative; display:grid; grid-template-columns:auto 1fr; gap:12px; align-items:flex-start;
  padding:12px 14px 16px 10px; border-radius:18px; border:1px solid rgba(43,47,51,.12); background:rgba(255,255,255,.92);
  box-shadow:0 20px 38px rgba(0,0,0,.12);
  backdrop-filter:blur(14px);
  margin:12px 0 18px 0; transition:transform .2s ease, box-shadow .2s ease;
}
.step:hover{ box-shadow:0 28px 52px rgba(0,0,0,.16); transform:translateY(-4px); }
.badge{
  width:32px; height:32px; border-radius:999px; display:grid; place-items:center; font-weight:900;
  background:var(--taupe); color:var(--slate-strong); box-shadow:inset 0 1px 0 rgba(255,255,255,.5), 0 2px 8px rgba(0,0,0,.06);
  border:1px solid rgba(43,47,51,.2); z-index:1;
}
.step-body h4{ margin:0 0 4px; font-size:1rem; color:var(--slate-strong); }
.step-body p{ margin:0; color:var(--muted); }

/* Bubble network panel */
.bubble-panel{
  position:relative; border:1px solid rgba(43,47,51,.14); border-radius:var(--radius-xl); background:rgba(255,255,255,.9);
  box-shadow:0 24px 48px rgba(0,0,0,.14); padding:22px; overflow:hidden;
  backdrop-filter:blur(16px);
}
#skillsGraph{ width:100%; height:420px; display:block; }
.bubble-fallback{ display:none; margin:10px 0 0 18px; color:var(--muted); }
@media (prefers-reduced-motion:reduce){
  #skillsGraph{ display:none; }
  .bubble-fallback{ display:block; }
}

/* -------------------- Footer -------------------- */
.footer{background:var(--paper);border-top:1px solid var(--line)}
.footer-inner{padding:18px 24px;display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:space-between;color:#737a82}

/* -------------------- Utility -------------------- */
.noscript{background:rgba(0,0,0,.05);border:1px dashed rgba(0,0,0,.12);border-radius:12px;padding:10px 14px;margin:16px 0}

/* -------------------- Reduced Motion -------------------- */
@media (prefers-reduced-motion:reduce){
  *{animation:none !important;transition:none !important;filter:none !important}
}
