/* ============================================================
   Nojus Liutikas — Editorial register (single surface)
   Flat black, hairlines, square edges, tight Inter display,
   small uppercase IBM Plex Mono labels, underlined links.
   Shared by the homepage and the résumé dossier so the two
   read as one coherent portfolio.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;500;600&family=Inter:wght@400;500;600;700&display=swap');

:root {
  --bg: #050505;
  --border: rgba(255,255,255,0.115);
  --border-accent: rgba(255,255,255,0.22);
  --border-strong: rgba(255,255,255,0.34);
  --text: #f2f2f0;
  --text-muted: #b6b5af;
  --text-dim: #8a8a83;
  --accent: #ffffff;
  --link: #b8b8b2;
  --green: #7ef0a1;
  --blue: #9dc8ff;
  --gold: #e8d9a6;
  --mono: 'IBM Plex Mono', monospace;
  --sans: 'Inter', system-ui, -apple-system, sans-serif;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
  min-height: 100vh;
  background: var(--bg);
  color: var(--text);
  font-family: var(--sans);
  font-weight: 400;
  line-height: 1.65;
  font-size: 15px;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
::selection { background: #f5f5f2; color: #050505; }

a { color: var(--link); text-decoration: none; transition: color .18s ease, border-color .18s ease, background .18s ease, transform .18s ease; }

.container { max-width: 1120px; margin: 0 auto; padding: 0 28px; position: relative; z-index: 1; }

/* ---- NAV (editorial — no glow dot) ---- */
nav { padding: 34px 0 56px; position: relative; z-index: 2; }
.nav-mark { position: absolute; inset: 0; width: 100%; height: 100%; pointer-events: none; z-index: 0; }
nav .container { display: flex; justify-content: space-between; align-items: center; position: relative; z-index: 1; }
.brand { font-family: var(--mono); font-size: 13px; font-weight: 500; color: var(--accent); letter-spacing: .02em; display: inline-flex; align-items: center; gap: 10px; cursor: pointer; background: none; border: 0; }
.nav-links { display: flex; gap: 28px; }
.nav-links a { font-family: var(--mono); font-size: 12px; color: var(--text-muted); letter-spacing: .06em; text-transform: lowercase; background: none; border: 0; cursor: pointer; transition: color .18s; }
.nav-links a:hover, .nav-links a.active { color: var(--text); }

/* ---- EDITORIAL LINK (underlined mono) ---- */
.editorial-link { font-family: var(--mono); text-transform: uppercase; letter-spacing: .12em; color: var(--text-muted); font-size: 11px; border-bottom: 1px solid var(--border-accent); padding-bottom: 5px; background: none; border-top: 0; border-left: 0; border-right: 0; cursor: pointer; display: inline-flex; align-items: center; gap: 7px; }
.hero-actions .editorial-link { display: inline-flex; }
.editorial-link:hover { color: var(--text); border-color: var(--text); }
.link-icon { width: 13px; height: 13px; flex: 0 0 auto; fill: none; stroke: currentColor; stroke-width: 1.35; stroke-linecap: square; stroke-linejoin: miter; opacity: .78; }

/* ============================================================
   HOMEPAGE register (ported from Home.jsx / landing)
   ============================================================ */
.hero { display: block; max-width: 980px; padding-bottom: 60px; }
.hero-kicker { font-family: var(--mono); text-transform: uppercase; letter-spacing: .12em; color: var(--text-dim); font-size: 11px; margin-bottom: 24px; }
.hero h1 { font-size: clamp(54px, 8.6vw, 104px); letter-spacing: -.078em; line-height: .93; color: var(--accent); max-width: 990px; margin-bottom: 30px; font-weight: 650; }
.hero-lede { color: var(--text-muted); font-size: clamp(17px, 2vw, 21px); line-height: 1.56; max-width: 760px; margin-bottom: 36px; }
.hero-actions { display: flex; flex-wrap: wrap; align-items: center; gap: 18px 26px; }

.principles { border-top: 0; padding: 0 0 72px; }
.principles::before { content: ""; display: block; height: 1px; margin-bottom: 28px; background: linear-gradient(90deg, var(--border) 0%, rgba(255,255,255,0.07) 58%, transparent 100%); }
.home-section { border-top: 1px solid var(--border); padding: 112px 0; }
.section-label { font-family: var(--mono); font-size: 11px; color: var(--text-dim); text-transform: uppercase; letter-spacing: .14em; margin-bottom: 14px; }
.section-head { display: grid; grid-template-columns: minmax(0,1fr) minmax(260px,370px); gap: 56px; align-items: end; margin-bottom: 58px; }
.compact-head { grid-template-columns: 1fr; max-width: 720px; }
.section-head h2 { font-size: clamp(32px, 4.4vw, 54px); line-height: 1.02; letter-spacing: -.056em; max-width: 760px; font-weight: 650; }
.section-head p { max-width: 390px; font-size: 15px; line-height: 1.65; color: var(--text-muted); }

.principles-grid { display: grid; grid-template-columns: repeat(4, minmax(0,1fr)); gap: 34px 44px; }
.principles-grid p { min-height: 112px; padding: 0; color: var(--text); font-size: 18px; line-height: 1.35; letter-spacing: -.02em; }
.principles-grid span { display: block; font-family: var(--mono); font-size: 11px; color: var(--text-dim); letter-spacing: .12em; margin-bottom: 22px; }
.principles-grid span::after { content: ""; display: block; width: 58px; height: 7px; margin-top: 18px; opacity: .62; background: url("data:image/svg+xml,%3Csvg width='58' height='7' viewBox='0 0 58 7' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 4 C5 1 9 1 13 4 S21 7 25 4 S33 1 37 4 S45 7 49 4 S55 1 57 3.5' fill='none' stroke='%238a8a83' stroke-width='1' stroke-linecap='round'/%3E%3C/svg%3E") left center / 58px 7px no-repeat; }

.project-list { border-top: 1px solid var(--border); }
.project-entry, .secondary-project { display: grid; grid-template-columns: 220px minmax(0,1fr); gap: 56px; border-bottom: 1px solid var(--border); }
.project-entry { padding: 54px 0 62px; }
.featured-project { padding-top: 66px; }
.secondary-project { padding: 38px 0; }
.project-meta { display: flex; flex-direction: column; gap: 10px; color: var(--text-dim); font-size: 11px; font-family: var(--mono); text-transform: uppercase; letter-spacing: .12em; }
.project-meta span:first-child { color: var(--text-muted); }
.project-content { max-width: 780px; }
.project-heading { display: flex; justify-content: space-between; gap: 28px; align-items: baseline; margin-bottom: 20px; }
.project-heading h3 { color: var(--text); font-size: clamp(34px, 5vw, 64px); line-height: .98; letter-spacing: -.062em; font-weight: 650; }
.major-project .project-heading h3 { font-size: clamp(30px, 4vw, 50px); }
.small-heading h3 { font-size: clamp(24px, 3vw, 34px); letter-spacing: -.045em; }
.project-heading a { font-family: var(--mono); text-transform: uppercase; letter-spacing: .12em; color: var(--text-muted); font-size: 11px; border-bottom: 1px solid var(--border-accent); padding-bottom: 5px; cursor: pointer; white-space: nowrap; }
.project-heading a:hover { color: var(--text); border-color: var(--text); }
.project-thesis { color: var(--text-muted); font-size: clamp(18px, 2.2vw, 24px); line-height: 1.42; letter-spacing: -.025em; max-width: 760px; margin-bottom: 42px; }
.project-facts { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 28px; margin-bottom: 34px; }
.project-facts.compact { grid-template-columns: repeat(2, minmax(0,1fr)); }
.project-facts dt { font-family: var(--mono); font-size: 11px; color: var(--text-dim); text-transform: uppercase; letter-spacing: .12em; margin-bottom: 10px; }
.project-facts dd, .secondary-project p { color: var(--text-muted); font-size: 15px; line-height: 1.65; }
.project-stack { font-family: var(--mono); text-transform: uppercase; letter-spacing: .12em; color: var(--text-dim); font-size: 11px; margin-top: 24px; }

.writing-list { border-top: 1px solid var(--border); }
.writing-item { display: grid; grid-template-columns: 1fr auto; align-items: baseline; gap: 24px; padding: 24px 0; color: var(--text); border-bottom: 1px solid var(--border); }
.writing-item[href] { cursor: pointer; }
.writing-item span { font-size: 17px; letter-spacing: -.01em; }
.writing-item em { font-family: var(--mono); font-style: normal; font-size: 11px; color: var(--text-dim); white-space: nowrap; }
.writing-item.placeholder-item span { color: var(--text-muted); }
.writing-item.muted-item span { color: var(--text-dim); }

.contact-panel { display: grid; grid-template-columns: minmax(0,1fr) auto; gap: 56px; align-items: end; border-top: 1px solid var(--border); padding: 112px 0 98px; }
.contact-panel h2 { font-size: clamp(32px, 4.4vw, 54px); line-height: 1.02; letter-spacing: -.056em; max-width: 760px; font-weight: 650; }
.contact-panel p { color: var(--text-muted); max-width: 720px; margin-top: 22px; font-size: 16px; }
.contact-links { display: flex; flex-wrap: wrap; justify-content: flex-end; gap: 16px 24px; }

footer { padding: 24px 0 44px; border-top: 1px solid var(--border); margin-top: 12px; }
footer p { font-family: var(--mono); font-size: 11px; color: var(--text-dim); text-align: center; }

/* ============================================================
   RÉSUMÉ DOSSIER — editorial continuation of the homepage.
   Reuses the homepage row grammar (meta column + content),
   hairline dividers, square edges. No cards / glass / pills.
   ============================================================ */

.resume-hero { padding-bottom: 52px; }
.resume-hero h1 { font-size: clamp(48px, 7.4vw, 84px); }
.resume-hero .hero-lede { max-width: 720px; }
.hero-meta { font-family: var(--mono); text-transform: uppercase; letter-spacing: .12em; color: var(--text-dim); font-size: 11px; margin-top: 34px; }

.dossier-section { border-top: 1px solid var(--border); }
.resume-section { border-top: 1px solid var(--border); padding: 72px 0; }
.resume-section .section-head { margin-bottom: 42px; }
.resume-section .section-head h2 { font-size: clamp(28px, 3.8vw, 44px); }
.resume-list { border-top: 1px solid var(--border); }
.entry,
.resume-project { display: grid; grid-template-columns: 220px minmax(0,1fr); gap: 56px; border-bottom: 1px solid var(--border); padding: 34px 0 38px; }
.entry-meta { display: flex; flex-direction: column; gap: 10px; color: var(--text-dim); font-size: 11px; font-family: var(--mono); text-transform: uppercase; letter-spacing: .12em; }
.entry-meta .ord { color: var(--text-muted); }
.entry-content { max-width: 820px; }

.entry-title { color: var(--text); font-size: clamp(24px, 3vw, 34px); line-height: 1.03; letter-spacing: -.045em; font-weight: 650; margin-bottom: 12px; }
.entry-org { color: var(--text-muted); font-size: 15px; letter-spacing: -.01em; margin-bottom: 16px; }
.resume-project-heading { display: flex; justify-content: space-between; gap: 28px; align-items: baseline; margin-bottom: 14px; }
.resume-project-heading h3 { color: var(--text); font-size: clamp(26px, 3.4vw, 38px); line-height: 1.02; letter-spacing: -.05em; font-weight: 650; }
.resume-project-heading a { font-family: var(--mono); text-transform: uppercase; letter-spacing: .12em; color: var(--text-muted); font-size: 11px; border-bottom: 1px solid var(--border-accent); padding-bottom: 5px; white-space: nowrap; }
.resume-project-heading a:hover { color: var(--text); border-color: var(--text); }
.resume-thesis { color: var(--text-muted); font-size: 17px; line-height: 1.48; letter-spacing: -.015em; max-width: 720px; margin-bottom: 18px; }
.resume-project .project-stack { margin-top: 16px; }

.entry-points { display: flex; flex-direction: column; }
.entry-points li { list-style: none; color: var(--text-muted); font-size: 15px; line-height: 1.58; padding: 10px 0 10px 24px; border-top: 1px solid var(--border); position: relative; max-width: 760px; }
.entry-points li:first-child { border-top: 0; padding-top: 0; }
.entry-points li:first-child::before { top: 0.62em; }
.entry-points li::before { content: ""; position: absolute; left: 0; top: calc(0.62em + 10px); width: 12px; height: 1px; background: var(--border-strong); }

.fact-block { margin-top: 18px; }
.fact-block .fact-label { font-family: var(--mono); font-size: 11px; color: var(--text-dim); text-transform: uppercase; letter-spacing: .12em; margin-bottom: 10px; }
.fact-block p { color: var(--text-muted); font-size: 15px; line-height: 1.62; max-width: 720px; }
.fact-grid-2 { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 28px; margin-top: 18px; }
@media (max-width: 760px) { .fact-grid-2 { grid-template-columns: 1fr; } }

.skills-grid-editorial { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); border-top: 1px solid var(--border); }
.skill-cell { display: grid; grid-template-columns: 150px minmax(0,1fr); gap: 24px; padding: 20px 0; border-bottom: 1px solid var(--border); }
.skill-cell .skill-label { font-family: var(--mono); font-size: 11px; color: var(--text-dim); text-transform: uppercase; letter-spacing: .14em; }
.skill-cell .skill-value { color: var(--text-muted); font-size: 15px; line-height: 1.6; }
.skill-cell:nth-child(-n + 3) .skill-label,
.skill-cell:nth-child(-n + 3) .skill-value { color: var(--text); }

/* ============================================================
   BRAND MARK - orbit-and-relieve motion in the nav band.
   Canvas owns the motion; CSS only reserves the band.
   ============================================================ */

/* ---- RESPONSIVE ---- */
@media (max-width: 900px) {
  nav { padding-bottom: 48px; }
  .hero { padding-bottom: 52px; }
  .resume-hero { padding-bottom: 48px; }
  .principles { padding-bottom: 88px; }
  .principles-grid { grid-template-columns: repeat(2, minmax(0,1fr)); gap: 34px 48px; }
  .section-head, .contact-panel { grid-template-columns: 1fr; align-items: start; }
  .project-entry, .secondary-project, .entry, .resume-project { grid-template-columns: 1fr; gap: 24px; }
  .project-meta, .entry-meta { flex-direction: row; flex-wrap: wrap; gap: 18px; }
  .project-facts, .project-facts.compact { grid-template-columns: 1fr; gap: 22px; }
  .contact-links { justify-content: flex-start; }
  .resume-section { padding: 64px 0; }
  .skills-grid-editorial { grid-template-columns: 1fr; }
}
@media (max-width: 620px) {
  .container { padding: 0 18px; }
  nav { padding-top: 24px; padding-bottom: 40px; }
  nav .container { flex-direction: column; align-items: flex-start; gap: 18px; }
  .nav-links { gap: 16px; flex-wrap: wrap; }
  .hero h1 { font-size: clamp(42px, 14vw, 62px); letter-spacing: -.065em; }
  .resume-hero h1 { font-size: clamp(42px, 13vw, 58px); }
  .home-section { padding: 82px 0; }
  .resume-section { padding: 56px 0; }
  .principles-grid { grid-template-columns: 1fr; }
  .principles-grid p { min-height: auto; }
  .entry, .resume-project { padding: 30px 0 34px; }
  .project-heading, .resume-project-heading { flex-direction: column; align-items: flex-start; gap: 12px; }
  .skill-cell { grid-template-columns: 1fr; gap: 8px; padding: 18px 0; }
}
