/* ============================================================
   COMPONENTS — components.css
   Cursor, nav, drawer, AOS, buttons, pills, tags
   ============================================================ */

/* ── Scroll progress bar ── */
#scroll-progress {
  position: fixed;
  top: 0; left: 0;
  height: 2px;
  width: 0%;
  background: linear-gradient(90deg, var(--amber), var(--teal2), var(--violet2));
  z-index: 9999;
  transition: width .08s linear;
}

/* ── Skip to content ── */
.skip-link {
  position: absolute;
  top: -100px; left: 1rem;
  background: var(--amber);
  color: #000;
  padding: .5rem 1.2rem;
  border-radius: 0 0 var(--r-sm) var(--r-sm);
  font-size: .82rem; font-weight: 700;
  z-index: 9999; transition: top .2s;
}
.skip-link:focus { top: 0; }

/* Custom cursor removed per user feedback to reduce distraction */

/* ── NAV ── */
#nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 500;
  display: flex; align-items: center; justify-content: space-between;
  padding: 1rem 1.5rem;
  transition: background .4s, backdrop-filter .4s, border-bottom .4s;
}
#nav.scrolled {
  background: rgba(7, 8, 15, .72);
  backdrop-filter: blur(28px) saturate(180%);
  border-bottom: 1px solid var(--border);
}
.nav-logo {
  font-family: 'Fraunces', serif; font-style: italic;
  font-size: 1.25rem; color: var(--amber2); font-weight: 300; position: relative; z-index: 2;
}
.nav-logo::before {
  content: ''; position: absolute; inset: -8px; border-radius: 50%;
  background: radial-gradient(circle, rgba(56,189,248,.2), transparent 70%);
  opacity: 0; transition: opacity .3s;
}
.nav-logo:hover::before { opacity: 1; }

/* Nav resume button */
.nav-resume-btn {
  font-size: .68rem; letter-spacing: .12em; text-transform: uppercase;
  color: var(--muted); font-weight: 700;
  padding: .32rem .8rem; border: 1px solid var(--border);
  border-radius: 6px; transition: all .22s;
}
.nav-resume-btn:hover { border-color: var(--border2); color: var(--amber2); background: rgba(56,189,248,.08); }

.nav-right { display: none; align-items: center; gap: 1.6rem; }
@media (min-width: 900px) { .nav-right { display: flex; } }

.nav-links-desk { display: flex; gap: 1.6rem; list-style: none; }
.nav-links-desk a {
  font-size: .7rem; letter-spacing: .16em; text-transform: uppercase; color: var(--muted);
  position: relative; padding: .2rem 0; transition: color .2s;
}
.nav-links-desk a::after {
  content: ''; position: absolute; bottom: -2px; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, var(--amber), var(--teal2));
  transform: scaleX(0); transform-origin: right;
  transition: transform .3s cubic-bezier(.23,1,.32,1);
}
.nav-links-desk a:hover { color: var(--amber2); }
.nav-links-desk a:hover::after { transform: scaleX(1); transform-origin: left; }

.nav-cta {
  background: linear-gradient(135deg, var(--amber), #0284c7);
  color: #07080f; padding: .48rem 1.2rem; border-radius: 100px;
  font-size: .7rem; font-weight: 800; letter-spacing: .08em; text-transform: uppercase;
  transition: transform .2s, box-shadow .2s; position: relative; overflow: hidden;
}
.nav-cta::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,.25) 50%, transparent 70%);
  transform: translateX(-100%); transition: transform .5s;
}
.nav-cta:hover { transform: translateY(-1px); box-shadow: 0 8px 22px rgba(56,189,248,.4); }
.nav-cta:hover::before { transform: translateX(100%); }

/* Hamburger */
.ham {
  background: none; border: 1px solid var(--border2); border-radius: 9px;
  width: 40px; height: 40px;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 5px; padding: 0; transition: border-color .2s;
}
.ham span { display: block; width: 18px; height: 1.5px; background: var(--ink); transition: transform .3s, opacity .3s; }
.ham.open span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.ham.open span:nth-child(2) { opacity: 0; }
.ham.open span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }
@media (min-width: 900px) { .ham { display: none; } }

/* Mobile Drawer */
#drawer {
  position: fixed; inset: 0; top: 62px; z-index: 499;
  background: #07080f;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 2rem; opacity: 0; pointer-events: none; transition: opacity .3s;
}
#drawer.open { opacity: 1; pointer-events: all; }
#drawer a {
  font-family: 'Fraunces', serif; font-style: italic;
  font-size: 2rem; color: var(--ink); transition: color .2s;
}
#drawer a:hover { color: var(--amber2); }
.drawer-cta-btn {
  font-family: 'Plus Jakarta Sans', sans-serif !important; font-style: normal !important;
  font-size: .9rem !important;
  background: linear-gradient(135deg, var(--amber), #0284c7) !important;
  color: #07080f !important; padding: .8rem 2.4rem !important;
  border-radius: 100px !important; font-weight: 800 !important;
}

/* ── AOS animation base ── */
[data-aos] {
  opacity: 0;
  transition: opacity .7s cubic-bezier(.23,1,.32,1), transform .7s cubic-bezier(.23,1,.32,1);
}
[data-aos="fade-up"]   { transform: translateY(28px); }
[data-aos="fade-left"] { transform: translateX(24px); }
[data-aos="fade-right"]{ transform: translateX(-24px); }
[data-aos="zoom-in"]   { transform: scale(.92); }
[data-aos].in { opacity: 1; transform: none; }

/* ── Shared Buttons ── */
.btn-p {
  background: linear-gradient(135deg, var(--amber), #0284c7);
  color: #07080f; padding: .82rem 1.7rem; border-radius: 100px;
  font-size: .82rem; font-weight: 800; letter-spacing: .06em;
  display: inline-flex; align-items: center; gap: .4rem;
  transition: all .25s; position: relative; overflow: hidden;
}
.btn-p::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,.2) 50%, transparent 70%);
  transform: translateX(-100%); transition: transform .5s;
}
.btn-p:hover { transform: translateY(-2px); box-shadow: 0 14px 28px rgba(56,189,248,.38); }
.btn-p:hover::before { transform: translateX(100%); }

.btn-s {
  border: 1px solid var(--border2); color: var(--amber2); padding: .82rem 1.7rem;
  border-radius: 100px; font-size: .82rem; font-weight: 600;
  display: inline-flex; align-items: center; gap: .4rem; transition: all .25s;
}
.btn-s:hover { background: rgba(56,189,248,.1); border-color: var(--amber2); transform: translateY(-2px); }

/* ── Tags / Pills ── */
.tags-row { display: flex; flex-wrap: wrap; gap: .45rem; margin-top: 1.5rem; }
.tag {
  border: 1px solid var(--border2); color: var(--amber3);
  font-size: .65rem; letter-spacing: .07em; padding: .28rem .8rem;
  border-radius: 100px; transition: all .2s;
}
.tag:hover { background: rgba(56,189,248,.1); border-color: var(--amber2); }

.pills { display: flex; flex-wrap: wrap; gap: .3rem; margin-top: .5rem; }
.pill {
  font-size: .6rem; padding: .2rem .65rem;
  border: 1px solid var(--border); color: var(--muted);
  border-radius: 4px; letter-spacing: .05em;
}

/* ── Timeline shared ── */
.tl-ach {
  display: inline-flex; align-items: center; gap: .4rem;
  background: rgba(56,189,248,.1); border: 1px solid rgba(56,189,248,.22);
  color: var(--amber2); font-size: .68rem; font-weight: 700;
  padding: .32rem .8rem; border-radius: 6px; margin-top: .7rem; margin-bottom: .5rem;
}
