:root {
  --bg: #1b1c22;
  --surface: #232530;
  --surface-raised: #2b2d3a;
  --ink: #e4ddd2;
  --ink-bright: #f0ebe3;
  --ink-secondary: #a59e94;
  --accent: #c87a50;
  --accent-bright: #de9468;
  --steel: #7faccf;
  --line: #30323e;
  --radius: 12px;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

::selection {
  background: rgba(200, 122, 80, 0.3);
  color: var(--ink-bright);
}

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

body {
  margin: 0;
  background-color: var(--bg);
  background-image:
    radial-gradient(
      ellipse at 15% 5%,
      rgba(200, 122, 80, 0.04) 0%,
      transparent 50%
    ),
    radial-gradient(
      ellipse at 85% 95%,
      rgba(127, 172, 207, 0.03) 0%,
      transparent 50%
    );
  color: var(--ink);
  font-family: "Manrope", "Segoe UI", sans-serif;
  line-height: 1.65;
}

body::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 40;
  opacity: 0.03;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 200px 200px;
}

img {
  max-width: 100%;
  display: block;
}

a {
  color: var(--steel);
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
  transition: color 180ms ease;
}

a:hover,
a:focus-visible {
  color: var(--accent-bright);
}

.skip-link {
  position: absolute;
  left: -9999px;
  top: 8px;
  background: var(--accent);
  color: #fff;
  padding: 0.5rem 0.8rem;
  border-radius: 6px;
}

.skip-link:focus {
  left: 8px;
  z-index: 100;
}

.wrap {
  width: min(1120px, 92vw);
  margin: 0 auto;
}

.narrow {
  width: min(800px, 92vw);
}

/* --- Header --- */

.site-header {
  position: sticky;
  top: 0;
  z-index: 25;
  backdrop-filter: blur(12px);
  background: color-mix(in srgb, var(--bg) 85%, transparent);
  border-bottom: 1px solid var(--line);
}

.nav-wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 64px;
}

.brand {
  font-family: "Newsreader", Georgia, serif;
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--accent);
  text-decoration: none;
  letter-spacing: 0.04em;
  transition: color 180ms ease;
}

.brand:hover {
  color: var(--accent-bright);
}

nav ul {
  display: flex;
  list-style: none;
  gap: 1.2rem;
  margin: 0;
  padding: 0;
}

nav a {
  text-decoration: none;
  font-size: 0.82rem;
  color: var(--ink-secondary);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  transition: color 180ms ease;
}

nav a:hover {
  color: var(--ink);
}

/* --- Hero --- */

.hero {
  position: relative;
  overflow: clip;
}

.hero::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(
    to right,
    transparent,
    var(--accent) 20%,
    var(--accent) 80%,
    transparent
  );
  opacity: 0.3;
  z-index: 1;
}

.hero-bg {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(
      105deg,
      rgba(27, 28, 34, 0.9) 10%,
      rgba(27, 28, 34, 0.55) 52%,
      rgba(27, 28, 34, 0.85) 100%
    ),
    url("./images/rose-hero.jpg");
  background-size: cover;
  background-position: center;
  filter: saturate(1.1) contrast(1.02);
}

.hero-grid {
  position: relative;
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  align-items: center;
  gap: clamp(1.5rem, 4vw, 3.2rem);
  padding: clamp(3.5rem, 8vw, 7rem) 0 clamp(2.8rem, 6vw, 5rem);
}

h1,
h2,
h3 {
  font-family: "Newsreader", Georgia, serif;
  line-height: 1.15;
  margin-top: 0;
  color: var(--ink-bright);
}

h1 {
  font-size: clamp(2.4rem, 7vw, 4.6rem);
  margin: 0.45rem 0;
}

h2 {
  font-size: clamp(1.65rem, 4vw, 2.4rem);
  margin-bottom: 1.1rem;
}

.tagline {
  font-size: clamp(1.15rem, 2.3vw, 1.45rem);
  max-width: 42ch;
  margin: 0 0 1rem;
  color: var(--ink);
}

.intro {
  max-width: 60ch;
  margin: 0;
  color: var(--ink-secondary);
  line-height: 1.7;
}

/* --- Profile --- */

.profile-wrap {
  margin: 0;
  justify-self: center;
  transform: rotate(-0.8deg);
}

.profile-wrap img {
  width: min(360px, 78vw);
  height: min(360px, 78vw);
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 20px;
  border: 4px solid rgba(200, 122, 80, 0.25);
  box-shadow:
    0 24px 64px rgba(0, 0, 0, 0.5),
    0 8px 20px rgba(200, 122, 80, 0.1);
}

/* --- Sections --- */

.section {
  padding: clamp(2.8rem, 8vw, 5rem) 0;
}

.section-note {
  margin-top: -0.4rem;
  color: var(--ink-secondary);
  font-size: 0.82rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.visual-context {
  max-width: 70ch;
  margin: 0 0 1.1rem;
  color: var(--ink-secondary);
}

/* --- Story list + Facts --- */

.story-list,
.facts {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 1.2rem;
}

.story-list li,
.facts li {
  padding: 1rem 0;
  border-bottom: 1px solid var(--line);
}

.story-list h3 {
  margin: 0 0 0.45rem;
  font-size: clamp(1.15rem, 2.2vw, 1.45rem);
}

.story-list p,
.facts li {
  margin: 0;
  color: var(--ink-secondary);
}

/* --- Writing / Essays --- */

.writing-essays {
  display: grid;
  gap: 0.9rem;
}

.essay-card {
  border: 1px solid var(--line);
  border-left: 3px solid var(--accent);
  border-radius: 0 var(--radius) var(--radius) 0;
  background: var(--surface);
  padding: 0.1rem 1.2rem 0.85rem;
  transition:
    border-color 200ms ease,
    background 200ms ease;
}

.essay-card[open] {
  border-left-color: var(--accent-bright);
  background: var(--surface-raised);
}

.essay-card summary {
  list-style: none;
  cursor: pointer;
  font-family: "Newsreader", Georgia, serif;
  font-size: clamp(1.1rem, 2vw, 1.35rem);
  font-weight: 700;
  line-height: 1.25;
  padding: 0.85rem 1.9rem 0.5rem 0;
  position: relative;
  color: var(--ink-bright);
  transition: color 180ms ease;
}

.essay-card summary:hover {
  color: var(--accent-bright);
}

.essay-card summary::-webkit-details-marker {
  display: none;
}

.essay-card summary::after {
  content: "+";
  position: absolute;
  right: 0;
  top: 0.8rem;
  color: var(--accent);
  font-size: 1.2rem;
  line-height: 1;
  transition: color 180ms ease;
}

.essay-card[open] summary::after {
  content: "\2212";
  color: var(--accent-bright);
}

.essay-body {
  color: var(--ink-secondary);
  line-height: 1.7;
}

.essay-body p {
  margin: 0.65rem 0 0;
}

/* --- Visual / Gallery --- */

.visual {
  position: relative;
  margin-top: clamp(0.8rem, 3vw, 1.7rem);
}

.visual::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(200, 122, 80, 0.03),
    rgba(127, 172, 207, 0.02)
  );
  pointer-events: none;
}

.gallery {
  position: relative;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.tile {
  border: 1px solid var(--line);
  background: transparent;
  padding: 0;
  border-radius: var(--radius);
  overflow: clip;
  cursor: zoom-in;
  transition:
    border-color 200ms ease,
    box-shadow 200ms ease;
}

.tile:hover,
.tile:focus-visible {
  border-color: rgba(200, 122, 80, 0.3);
  box-shadow: 0 4px 20px rgba(200, 122, 80, 0.08);
}

.tile img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition:
    transform 220ms ease,
    filter 220ms ease;
}

.tile:hover img,
.tile:focus-visible img {
  transform: scale(1.028);
  filter: saturate(1.1) brightness(1.06);
}

/* --- Connect --- */

.connect {
  margin-top: clamp(0.8rem, 3vw, 1.7rem);
  padding-bottom: 6rem;
}

.contact-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 0.8rem;
}

.contact-list li {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
  border-bottom: 1px solid var(--line);
  padding-bottom: 0.7rem;
}

.contact-list span {
  min-width: 5.5rem;
  color: var(--ink-secondary);
  font-weight: 500;
  font-size: 0.85rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.placeholder {
  color: #4a4d55;
}

/* --- Lightbox --- */

.lightbox {
  position: fixed;
  inset: 0;
  z-index: 50;
  display: grid;
  place-items: center;
  background: rgba(10, 10, 14, 0.92);
  padding: 1rem;
}

.lightbox[hidden] {
  display: none;
}

.lightbox img {
  max-width: min(1200px, 95vw);
  max-height: 84vh;
  border-radius: 10px;
}

.lightbox-close {
  position: absolute;
  top: 14px;
  right: 14px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  background: rgba(27, 28, 34, 0.85);
  color: #fff;
  border-radius: 8px;
  padding: 0.45rem 0.65rem;
  cursor: pointer;
  transition: border-color 180ms ease;
}

.lightbox-close:hover {
  border-color: rgba(255, 255, 255, 0.4);
}

.lightbox-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  border: 1px solid rgba(255, 255, 255, 0.2);
  background: rgba(27, 28, 34, 0.85);
  color: #fff;
  border-radius: 8px;
  padding: 0.45rem 0.65rem;
  cursor: pointer;
  transition: border-color 180ms ease;
}

.lightbox-nav:hover {
  border-color: rgba(255, 255, 255, 0.4);
}

.lightbox-prev {
  left: 14px;
}

.lightbox-next {
  right: 14px;
}

/* --- Mobile --- */

@media (max-width: 860px) {
  nav ul {
    gap: 0.65rem;
    flex-wrap: wrap;
    justify-content: flex-end;
  }

  .hero-grid {
    grid-template-columns: 1fr;
    padding-top: 2.4rem;
  }

  .hero-bg {
    background-image: linear-gradient(
      115deg,
      rgba(27, 28, 34, 0.96) 0%,
      rgba(27, 28, 34, 0.92) 100%
    );
  }

  .profile-wrap {
    order: -1;
    justify-self: start;
  }

  .gallery {
    grid-template-columns: 1fr;
  }
}
