/* ── Reset & Variables ─────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  /* Palette: Onyx / Graphite / Bone / Burnt Peach / Wisteria Blue */
  --bg:          #0f110c;
  --graphite:    #333333;
  --bone:        #ece2d0;
  --peach:       #e9724c;
  --peach-rgb:   233, 114, 76;
  --blue:        #80a1d4;
  --blue-rgb:    128, 161, 212;

  --text:        var(--bone);
  --text-muted:  rgba(236, 226, 208, 0.52);
  --accent:      var(--peach);
  --panel:       rgba(15, 17, 12, 0.68);
  --border:      rgba(236, 226, 208, 0.09);
  --border-hov:  rgba(233, 114, 76, 0.55);

  --mono:        'JetBrains Mono', monospace;
  --sans:        'Inter', sans-serif;
  --radius:      22px;
  --transition:  0.25s ease;
}

html { scroll-behavior: smooth; }

body {
  font-family: var(--sans);
  background: transparent;
  color: var(--text);
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
}

/* ── Aurora ────────────────────────────────────────────────────── */
.aurora {
  position: fixed;
  inset: 0;
  z-index: 0;
  background: var(--bg);
  overflow: hidden;
  pointer-events: none;
}

.blob {
  position: absolute;
  border-radius: 50%;
  filter: blur(100px);
}

.blob-1 {
  width: 680px;
  height: 680px;
  background: radial-gradient(circle, rgba(233, 114, 76, 0.32) 0%, transparent 70%);
  top: -18%;
  left: -12%;
  animation: drift1 11s ease-in-out infinite;
}

.blob-2 {
  width: 620px;
  height: 620px;
  background: radial-gradient(circle, rgba(128, 161, 212, 0.28) 0%, transparent 70%);
  bottom: -12%;
  right: -10%;
  animation: drift2 14s ease-in-out infinite;
}

.blob-3 {
  width: 500px;
  height: 500px;
  background: radial-gradient(circle, rgba(233, 114, 76, 0.16) 0%, transparent 70%);
  top: 40%;
  left: 35%;
  animation: drift3 17s ease-in-out infinite;
}

.blob-4 {
  width: 440px;
  height: 440px;
  background: radial-gradient(circle, rgba(128, 161, 212, 0.2) 0%, transparent 70%);
  top: 15%;
  right: 15%;
  animation: drift4 13s ease-in-out infinite;
}

@keyframes drift1 {
  0%   { transform: translate(0, 0)           scale(1); }
  20%  { transform: translate(130px, 110px)   scale(1.18); }
  45%  { transform: translate(80px,  260px)   scale(0.88); }
  70%  { transform: translate(-100px, 150px)  scale(1.12); }
  100% { transform: translate(0, 0)           scale(1); }
}
@keyframes drift2 {
  0%   { transform: translate(0, 0)            scale(1); }
  20%  { transform: translate(-150px, -120px)  scale(1.14); }
  45%  { transform: translate(-90px, -240px)   scale(0.85); }
  70%  { transform: translate(110px, -100px)   scale(1.1); }
  100% { transform: translate(0, 0)            scale(1); }
}
@keyframes drift3 {
  0%   { transform: scale(1)    translate(0, 0); }
  30%  { transform: scale(1.28) translate(100px, -90px); }
  65%  { transform: scale(0.78) translate(-120px, 100px); }
  100% { transform: scale(1)    translate(0, 0); }
}
@keyframes drift4 {
  0%   { transform: translate(0, 0)          scale(1); }
  35%  { transform: translate(-110px, 140px) scale(1.2); }
  70%  { transform: translate(80px, 200px)   scale(0.88); }
  100% { transform: translate(0, 0)          scale(1); }
}

/* ── Scroll reveal ─────────────────────────────────────────────── */
.reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.55s ease, transform 0.55s ease;
}
.reveal.visible { opacity: 1; transform: none; }

/* ── Bento grid ────────────────────────────────────────────────── */
main.bento {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0.85rem;
  max-width: 920px;
  margin: 0 auto;
  padding: 1.5rem 1.5rem 0.85rem;
}

/* ── Panels ────────────────────────────────────────────────────── */
.panel {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.75rem;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  box-shadow:
    inset 0 1px 0 rgba(236, 226, 208, 0.06),
    0 4px 28px rgba(0, 0, 0, 0.4);
  transition: border-color var(--transition), transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1), box-shadow 0.3s ease;
}


/* Staggered layout — row 1 breaks at col 3|4, row 2 breaks at col 2|3 */
.panel-hero     { grid-column: 1 / 4; grid-row: 1; display: flex; flex-direction: column; justify-content: center; }
.panel-photo    { grid-column: 4 / 6; grid-row: 1; padding: 0; overflow: hidden; }
.panel-about    { grid-column: 1 / 3; grid-row: 2; }
.panel-exp      { grid-column: 3 / 6; grid-row: 2; }
.panel-skills   { grid-column: 1 / 6; grid-row: 3; }
.panel-projects { grid-column: 1 / 6; grid-row: 4; }
.panel-contact  { grid-column: 1 / 6; grid-row: 5; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 1.5rem; }

/* Photo panel */
.photo-frame {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 280px;
}
.photo-frame img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
  opacity: 0;
  transition: opacity 0.4s ease;
  border-radius: var(--radius);
}
.photo-frame img.loaded { opacity: 1; }
.photo-placeholder {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  background: linear-gradient(145deg, rgba(233,114,76,0.12), rgba(128,161,212,0.12));
  border-radius: var(--radius);
}
.photo-placeholder svg { width: 52px; height: 52px; color: var(--text-muted); opacity: 0.4; }
.photo-placeholder p { font-size: 0.8rem; color: var(--text-muted); text-align: center; line-height: 1.6; opacity: 0.6; }
.photo-placeholder code { font-family: var(--mono); font-size: 0.75rem; color: var(--peach); }

/* Experience timeline layout */
.exp-entries {
  display: flex;
  flex-direction: column;
}
.exp-entry {
  display: grid;
  grid-template-columns: 130px 1fr;
  gap: 0.5rem 1.25rem;
  padding: 1.1rem 0;
}
.exp-entry + .exp-entry {
  border-top: 1px solid var(--border);
}
.exp-date {
  font-family: var(--mono);
  font-size: 0.72rem;
  color: var(--text-muted);
  line-height: 1.5;
  padding-top: 0.2rem;
}

.panel-label {
  font-family: var(--mono);
  font-size: 0.7rem;
  color: var(--peach);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  margin-bottom: 1.1rem;
  opacity: 0.85;
}

/* ── Hero panel ────────────────────────────────────────────────── */
.eyebrow {
  font-family: var(--mono);
  font-size: 0.78rem;
  color: var(--peach);
  letter-spacing: 0.08em;
  margin-bottom: 0.75rem;
  display: block;
}

.hero-name {
  font-size: clamp(2.2rem, 3.5vw, 3.4rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.05;
  margin-bottom: 1rem;
  color: var(--bone);
}

.hero-sub {
  color: var(--text-muted);
  font-size: 0.97rem;
  line-height: 1.7;
  max-width: 480px;
  margin-bottom: 1.75rem;
}

.hero-actions { display: flex; gap: 0.75rem; flex-wrap: wrap; margin-bottom: 1.5rem; }

.btn {
  padding: 0.65rem 1.4rem;
  border-radius: 8px;
  font-size: 0.88rem;
  font-weight: 600;
  text-decoration: none;
  transition: all var(--transition);
  border: none;
  cursor: pointer;
}
.btn-primary { background: var(--peach); color: #fff; }
.btn-primary:hover {
  background: #d4623f;
  transform: translateY(-2px);
  box-shadow: 0 6px 22px rgba(var(--peach-rgb), 0.38);
}
.btn-ghost { background: transparent; color: var(--bone); border: 1px solid var(--border); }
.btn-ghost:hover { border-color: rgba(236, 226, 208, 0.28); transform: translateY(-2px); }

.hero-location {
  font-family: var(--mono);
  font-size: 0.75rem;
  color: var(--text-muted);
  opacity: 0.7;
}

/* ── About panel ───────────────────────────────────────────────── */
.about-bio {
  color: var(--text-muted);
  font-size: 0.92rem;
  line-height: 1.7;
  margin-bottom: 1.5rem;
}

.stat-row {
  display: flex;
  gap: 1.5rem;
  border-top: 1px solid var(--border);
  padding-top: 1.25rem;
  flex-wrap: wrap;
}

.stat { display: flex; flex-direction: column; }
.stat-num {
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--peach);
  line-height: 1;
  margin-bottom: 0.25rem;
}
.stat-lbl { font-size: 0.75rem; color: var(--text-muted); }

/* ── Experience panel ──────────────────────────────────────────── */
.exp-title { font-size: 1rem; font-weight: 600; color: var(--bone); margin-bottom: 0.2rem; }
.exp-org   { font-size: 0.82rem; color: var(--peach); margin-bottom: 0.2rem; }
.exp-date  { font-family: var(--mono); font-size: 0.75rem; color: var(--text-muted); margin-bottom: 1rem; }

.bullet-list { list-style: none; display: flex; flex-direction: column; gap: 0.55rem; }
.bullet-list li {
  padding-left: 1.1rem;
  position: relative;
  color: var(--text-muted);
  font-size: 0.88rem;
  line-height: 1.6;
}
.bullet-list li::before {
  content: '▸';
  position: absolute;
  left: 0;
  color: var(--peach);
  font-size: 0.7rem;
  top: 0.25em;
}

/* ── Skills panel ──────────────────────────────────────────────── */
.skill-rows { display: flex; flex-direction: column; gap: 0.85rem; }

.skill-row { display: flex; align-items: flex-start; gap: 0.75rem; }
.skill-cat {
  font-family: var(--mono);
  font-size: 0.68rem;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  white-space: nowrap;
  min-width: 72px;
  padding-top: 0.25rem;
  opacity: 0.7;
}

.pills { display: flex; flex-wrap: wrap; gap: 0.35rem; }
.pill {
  font-size: 0.78rem;
  background: rgba(236, 226, 208, 0.04);
  color: var(--text-muted);
  border: 1px solid var(--border);
  border-radius: 5px;
  padding: 0.22rem 0.65rem;
  transition: all var(--transition);
}
.pill:hover { color: var(--bone); border-color: rgba(236, 226, 208, 0.22); }

/* ── Projects panel ────────────────────────────────────────────── */
.projects-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 0.85rem;
}

.project-card {
  background: rgba(15, 17, 12, 0.65);
  border: 1px solid var(--border);
  border-radius: 18px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  cursor: pointer;
  transition: border-color var(--transition), transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1), box-shadow 0.3s ease;
}

.project-thumb { width: 100%; height: 220px; overflow: hidden; flex-shrink: 0; }
.project-thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s ease; display: block; }
.project-thumb-placeholder { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; }
.project-thumb-placeholder svg { width: 40px; height: 40px; opacity: 0.28; color: #fff; }

.project-body { padding: 1rem 1.1rem 1.1rem; display: flex; flex-direction: column; gap: 0.6rem; flex: 1; }

.project-header { display: flex; justify-content: space-between; align-items: flex-start; gap: 0.4rem; }
.project-title   { font-size: 0.9rem; font-weight: 600; color: var(--bone); line-height: 1.3; }
.project-context { display: block; font-size: 0.72rem; color: var(--peach); margin-top: 0.15rem; }
.project-date    { font-family: var(--mono); font-size: 0.7rem; color: var(--text-muted); white-space: nowrap; }

.project-summary { color: var(--text-muted); font-size: 0.82rem; line-height: 1.55; flex: 1; }

.project-footer { display: flex; align-items: center; justify-content: space-between; gap: 0.4rem; margin-top: auto; }
.project-tags   { display: flex; flex-wrap: wrap; gap: 0.3rem; }

.tag {
  font-family: var(--mono);
  font-size: 0.65rem;
  color: var(--peach);
  background: rgba(233, 114, 76, 0.08);
  border: 1px solid rgba(233, 114, 76, 0.22);
  border-radius: 4px;
  padding: 0.15rem 0.45rem;
}

.project-more {
  font-size: 0.72rem;
  color: var(--text-muted);
  white-space: nowrap;
  flex-shrink: 0;
  transition: color var(--transition);
}
/* ── Contact panel ─────────────────────────────────────────────── */
.contact-left .panel-label { margin-bottom: 0.4rem; }
.contact-sub { color: var(--text-muted); font-size: 0.88rem; max-width: 340px; }

.contact-links { display: flex; gap: 0.85rem; flex-wrap: wrap; }
.contact-link {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  color: var(--text-muted);
  text-decoration: none;
  font-size: 0.88rem;
  padding: 0.65rem 1.25rem;
  border: 1px solid var(--border);
  border-radius: 8px;
  transition: all var(--transition);
}
.contact-link svg { width: 16px; height: 16px; flex-shrink: 0; }
.contact-link:hover {
  color: var(--peach);
  border-color: var(--border-hov);
  transform: translateY(-2px);
  box-shadow: 0 4px 16px rgba(var(--peach-rgb), 0.14);
}

/* ── Modal ─────────────────────────────────────────────────────── */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.75);
  backdrop-filter: blur(8px);
  z-index: 200;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.25s ease;
}
.modal-overlay.open { opacity: 1; pointer-events: all; }

.modal {
  background: rgba(15, 17, 12, 0.94);
  backdrop-filter: blur(20px);
  border: 1px solid var(--border);
  border-radius: 24px;
  width: 100%;
  max-width: 640px;
  max-height: 90vh;
  overflow-y: auto;
  position: relative;
  transform: translateY(20px) scale(0.98);
  transition: transform 0.25s ease;
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.65);
}
.modal-overlay.open .modal { transform: none; }

.modal-close {
  position: absolute;
  top: 1rem; right: 1rem;
  background: rgba(236, 226, 208, 0.05);
  border: 1px solid var(--border);
  border-radius: 8px;
  color: var(--text-muted);
  cursor: pointer;
  padding: 0.4rem;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1;
  transition: all var(--transition);
}
.modal-close:hover { color: var(--bone); border-color: rgba(236, 226, 208, 0.22); }
.modal-close svg { width: 18px; height: 18px; }

.modal-thumb { width: 100%; height: 220px; overflow: hidden; border-radius: 24px 24px 0 0; }
.modal-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.modal-thumb-placeholder { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; }
.modal-thumb-placeholder svg { width: 60px; height: 60px; opacity: 0.26; color: #fff; }

.modal-body { padding: 1.75rem; display: flex; flex-direction: column; gap: 1.1rem; }

.modal-meta { display: flex; justify-content: space-between; align-items: flex-start; gap: 1rem; flex-wrap: wrap; }
.modal-title   { font-size: 1.25rem; font-weight: 700; color: var(--bone); line-height: 1.2; }
.modal-context { display: block; font-size: 0.82rem; color: var(--peach); margin-top: 0.3rem; }
.modal-date    { font-family: var(--mono); font-size: 0.78rem; color: var(--text-muted); white-space: nowrap; }

.modal-desc { color: var(--text-muted); font-size: 0.93rem; line-height: 1.7; }

.modal-bullets { list-style: none; display: flex; flex-direction: column; gap: 0.55rem; }
.modal-bullets li {
  padding-left: 1.2rem;
  position: relative;
  color: var(--text-muted);
  font-size: 0.9rem;
  line-height: 1.6;
}
.modal-bullets li::before {
  content: '▸';
  position: absolute;
  left: 0;
  color: var(--peach);
  font-size: 0.72rem;
  top: 0.26em;
}
.modal-tags { display: flex; flex-wrap: wrap; gap: 0.4rem; }

/* ── Project detail page ───────────────────────────────────────── */
.project-page {
  position: relative;
  z-index: 1;
  max-width: 760px;
  margin: 0 auto;
  padding: 1.75rem 1.5rem 2.5rem;
}

.back-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  color: var(--text-muted);
  text-decoration: none;
  font-size: 0.85rem;
  margin-bottom: 1.75rem;
  transition: color var(--transition);
  letter-spacing: 0.01em;
}
.back-btn:hover { color: var(--bone); }
.back-btn svg { width: 16px; height: 16px; }

.proj-hero {
  border-radius: var(--radius);
  overflow: hidden;
  position: relative;
  height: 340px;
  margin-bottom: 1.1rem;
  display: flex;
  align-items: flex-end;
}
.proj-hero-icon {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.proj-hero model-viewer,
.proj-hero > img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.project-thumb model-viewer {
  width: 100%;
  height: 100%;
  display: block;
}
.proj-hero-icon svg { width: 88px; height: 88px; opacity: 0.22; color: #fff; }
.proj-hero-overlay {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 65%;
  background: linear-gradient(to top, rgba(15, 17, 12, 0.88) 0%, transparent 100%);
  pointer-events: none;
}
.proj-hero-meta {
  position: relative;
  z-index: 1;
  padding: 2rem;
  width: 100%;
}
.proj-title {
  font-size: clamp(1.4rem, 3.5vw, 2.1rem);
  font-weight: 700;
  color: var(--bone);
  line-height: 1.15;
  margin: 0.2rem 0 0.35rem;
  letter-spacing: -0.01em;
}
.proj-context {
  display: block;
  font-size: 0.78rem;
  color: var(--peach);
  font-family: var(--mono);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: 0.1rem;
}
.proj-date {
  font-family: var(--mono);
  font-size: 0.75rem;
  color: rgba(236, 226, 208, 0.5);
}

.proj-body {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.proj-panel {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.75rem;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  box-shadow: inset 0 1px 0 rgba(236, 226, 208, 0.06), 0 4px 28px rgba(0, 0, 0, 0.4);
}
.proj-desc {
  color: var(--text-muted);
  font-size: 0.95rem;
  line-height: 1.8;
}
.proj-bullets {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0.8rem;
  margin-top: 1.4rem;
}
.proj-bullets li {
  padding-left: 1.25rem;
  position: relative;
  color: var(--text-muted);
  font-size: 0.92rem;
  line-height: 1.65;
}
.proj-bullets li::before {
  content: '▸';
  position: absolute;
  left: 0;
  color: var(--peach);
  font-size: 0.7rem;
  top: 0.3em;
}
.proj-tags { display: flex; flex-wrap: wrap; gap: 0.45rem; }
.proj-not-found { padding: 3rem 0; color: var(--text-muted); }

a.project-card { text-decoration: none; color: inherit; }

/* ── Footer ────────────────────────────────────────────────────── */
footer {
  position: relative;
  z-index: 1;
  text-align: center;
  padding: 1.25rem;
  color: var(--text-muted);
  font-size: 0.78rem;
  opacity: 0.45;
}

/* ── Hover effects — desktop only ──────────────────────────────── */
@media (hover: hover) {
  .panel-about:hover,
  .panel-exp:hover,
  .panel-skills:hover {
    border-color: var(--border-hov);
    transform: translateY(-4px) scale(1.04);
    box-shadow: 0 16px 36px rgba(0, 0, 0, 0.55);
  }
  .project-card:hover {
    border-color: var(--border-hov);
    transform: translateY(-4px) scale(1.04);
    box-shadow: 0 16px 36px rgba(0, 0, 0, 0.55);
  }
  .project-card:hover .project-thumb img { transform: scale(1.05); }
  .project-card:hover .project-more { color: var(--peach); }
}

/* ── Responsive ────────────────────────────────────────────────── */
@media (max-width: 860px) {
  main.bento {
    grid-template-columns: 1fr;
    padding: 1rem 1rem 0.85rem;
    gap: 0.75rem;
  }
  .panel {
    padding: 1.35rem;
  }
  .panel-hero, .panel-photo, .panel-about, .panel-exp,
  .panel-skills, .panel-projects, .panel-contact {
    grid-column: 1;
    grid-row: auto;
  }
  .panel-photo   { min-height: 220px; }
  .photo-frame img { object-position: center 20%; }
  .panel-contact { flex-direction: column; align-items: flex-start; }
  .projects-grid { grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); }

  .exp-entry {
    grid-template-columns: 1fr;
    gap: 0.15rem;
  }
  .exp-date { padding-top: 0; margin-bottom: 0.5rem; }

  .skill-row { flex-direction: column; gap: 0.3rem; }
  .skill-cat { min-width: unset; }

  .stat-row { gap: 1rem; }
}

@media (max-width: 480px) {
  main.bento { padding: 0.75rem 0.75rem 0.75rem; gap: 0.6rem; }
  .panel     { padding: 1.1rem; }

  .hero-name { font-size: 2rem; }
  .hero-sub  { font-size: 0.9rem; }
  .hero-actions  { flex-direction: column; }

  .panel-photo { min-height: 180px; }

  .stat-row  { gap: 0.85rem; }
  .stat-num  { font-size: 1.3rem; }

  .contact-links { flex-direction: column; }
  .contact-link  { font-size: 0.82rem; padding: 0.55rem 1rem; }

  .projects-grid  { grid-template-columns: 1fr; }
  .project-thumb  { height: 180px; }

  .proj-hero      { height: 240px; }
  .proj-hero-meta { padding: 1.1rem; }
  .proj-title     { font-size: 1.25rem; }
}
