/* =========================================================
   Swiss-brutalist portfolio — paper light, vermilion accent
   Bricolage Grotesque display · Newsreader serif · JetBrains Mono
   ========================================================= */
:root {
  --paper: #f2efe6;
  --paper-2: #e9e5d8;
  --ink: #161412;
  --ink-soft: #5c574e;
  --accent: #f5350b;     /* electric vermilion */
  --line: #161412;
  --hair: rgba(22, 20, 18, 0.14);
  --disp: "Bricolage Grotesque", system-ui, sans-serif;
  --serif: "Newsreader", Georgia, serif;
  --mono: "JetBrains Mono", ui-monospace, monospace;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background: var(--paper);
  color: var(--ink);
  font-family: var(--serif);
  font-size: 17px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
::selection { background: var(--accent); color: var(--paper); }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }

.gutter { padding-inline: clamp(20px, 5vw, 64px); }
section { padding-inline: clamp(20px, 5vw, 64px); }

/* ---------- Top bar ---------- */
.bar {
  position: sticky; top: 0; z-index: 100;
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px clamp(20px, 5vw, 64px);
  background: var(--paper); border-bottom: 1px solid var(--line);
}
.logo { font-family: var(--disp); font-weight: 700; letter-spacing: -.02em; font-size: 1.05rem; }
.bar-right { display: flex; align-items: center; gap: 30px; }
.status { font-family: var(--mono); font-size: .72rem; text-transform: uppercase; letter-spacing: .08em; display: inline-flex; align-items: center; gap: 8px; }
.status i { width: 8px; height: 8px; border-radius: 50%; background: var(--accent); animation: pulse 1.8s infinite; }
@keyframes pulse { 0%,100%{ opacity: 1;} 50%{ opacity: .25;} }
.nav { display: flex; gap: 22px; font-family: var(--mono); font-size: .8rem; }
.nav a { position: relative; }
.nav a sup { color: var(--accent); font-size: .6em; }
.nav a:hover { color: var(--accent); }
@media (max-width: 680px) { .status { display: none; } }

/* ---------- Hero ---------- */
.hero { padding-top: clamp(40px, 8vw, 90px); padding-bottom: clamp(30px, 5vw, 60px); }
.hero-meta {
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: 12px;
  font-family: var(--mono); font-size: .78rem; text-transform: uppercase; letter-spacing: .08em;
  color: var(--ink-soft); border-bottom: 1px solid var(--hair); padding-bottom: 16px; margin-bottom: 36px;
}
.hero-meta em { font-style: normal; color: var(--accent); }
.hero-title {
  font-family: var(--disp); font-weight: 600; letter-spacing: -.035em;
  font-size: clamp(3rem, 12vw, 11rem); line-height: .92;
  text-transform: none;
}
.hero-title .hl { display: block; transform: translateY(110%); }
.hero-title .hl.show { transform: none; transition: transform 1s cubic-bezier(.16,1,.3,1); }
.hero-title .accent { color: var(--accent); font-style: italic; font-family: var(--serif); font-weight: 500; }
.hero-title .ast { display: inline-block; font-family: var(--disp); font-style: normal; font-size: .5em; vertical-align: super; animation: spin 9s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
.hero-lede { max-width: 46ch; margin-top: 40px; font-size: clamp(1.1rem, 2vw, 1.5rem); color: var(--ink-soft); margin-left: auto; }

/* ---------- Ticker ---------- */
.ticker { border-block: 1px solid var(--line); overflow: hidden; background: var(--ink); color: var(--paper); }
.ticker-row { display: inline-flex; align-items: center; gap: 28px; white-space: nowrap; padding: 14px 0; font-family: var(--disp); font-weight: 500; font-size: clamp(1rem, 2.4vw, 1.8rem); text-transform: uppercase; letter-spacing: .02em; animation: marq 26s linear infinite; }
.ticker-row .slash { color: var(--accent); }
@keyframes marq { to { transform: translateX(-50%); } }

/* ---------- Section labels ---------- */
.sec-label { font-family: var(--mono); font-size: .8rem; text-transform: uppercase; letter-spacing: .12em; padding-block: 28px; border-bottom: 1px solid var(--line); display: flex; gap: 14px; align-items: baseline; margin-bottom: 4px; }
.sec-label span { color: var(--accent); }
.sec-label.inv { color: var(--paper); border-color: var(--paper); }
.sec-label.inv span { color: var(--accent); }

/* ---------- Work grid (logo tiles) ---------- */
.work { padding-bottom: 8vh; }
.grid {
  display: grid; grid-template-columns: repeat(2, 1fr);
  border-top: 1px solid var(--line); border-left: 1px solid var(--line);
}
.card { border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.card-link { display: flex; flex-direction: column; height: 100%; transition: background .35s; }
.card-link:hover { background: var(--paper-2); }

/* logo tile */
.logo-tile {
  position: relative; aspect-ratio: 5 / 2; display: flex; align-items: center; justify-content: center;
  border-bottom: 1px solid var(--hair); overflow: hidden;
  background:
    linear-gradient(var(--hair) 1px, transparent 1px) 0 0 / 100% 22px,
    var(--paper);
}
.logo-tile .logo {
  max-height: 52px; max-width: 56%; width: auto; object-fit: contain;
  transition: transform .5s cubic-bezier(.16,1,.3,1);
}
.card-link:hover .logo-tile .logo { transform: scale(1.06); }
.monogram {
  display: flex; align-items: center; justify-content: center;
  width: 76px; height: 76px; border-radius: 16px;
  background: var(--ink); color: var(--paper);
  font-family: var(--disp); font-weight: 700; font-size: 1.9rem; letter-spacing: -.02em;
  transition: background .35s, transform .5s;
}
.card-link:hover .monogram { background: var(--accent); transform: scale(1.06); }
.tile-num {
  position: absolute; top: 12px; left: 14px;
  font-family: var(--mono); font-size: .72rem; color: var(--ink-soft);
}
.tile-num::before { content: "/ "; color: var(--accent); }

/* info block */
.card-info { padding: clamp(20px, 2.4vw, 30px); display: flex; flex-direction: column; flex: 1; }
.card-head { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; }
.card-title { font-family: var(--disp); font-weight: 600; letter-spacing: -.025em; font-size: clamp(1.4rem, 2.6vw, 2rem); line-height: 1.04; transition: color .25s; }
.card-link:hover .card-title { color: var(--accent); }
.card-arrow { font-size: 1.1rem; color: var(--ink-soft); transition: transform .35s, color .25s; }
.card-link:hover .card-arrow { transform: translate(4px, -4px); color: var(--accent); }
.card-domain { font-family: var(--mono); font-size: .78rem; color: var(--accent); margin-top: 6px; }
.card-summary { margin-top: 12px; color: var(--ink-soft); font-size: .96rem; flex: 1; }
.card-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 18px; }
.card-tags span { font-family: var(--mono); font-size: .68rem; text-transform: uppercase; letter-spacing: .06em; border: 1px solid var(--hair); border-radius: 999px; padding: 4px 11px; }
.empty { padding: 40px 0; color: var(--ink-soft); }
.empty code { font-family: var(--mono); color: var(--accent); }
@media (max-width: 720px) { .grid { grid-template-columns: 1fr; } }

/* ---------- About ---------- */
.about { padding-bottom: 8vh; }
.about-wrap { padding-top: 50px; }
.about-statement { font-family: var(--serif); font-weight: 300; font-size: clamp(1.6rem, 4vw, 3rem); line-height: 1.22; letter-spacing: -.01em; max-width: 22ch; }
.about-statement::first-letter { color: var(--accent); }
.exp { margin-top: 70px; border-top: 1px solid var(--line); }
.exp-row { display: grid; grid-template-columns: 180px 1.2fr 1fr; gap: 18px; padding: 26px 0; border-bottom: 1px solid var(--hair); align-items: baseline; }
.exp-period { font-family: var(--mono); font-size: .8rem; color: var(--accent); }
.exp-role { font-family: var(--disp); font-weight: 600; font-size: 1.15rem; }
.exp-co { color: var(--ink-soft); }
.exp-desc { grid-column: 2 / 4; color: var(--ink-soft); font-size: .98rem; }
@media (max-width: 720px) { .exp-row { grid-template-columns: 1fr; gap: 4px; } .exp-desc { grid-column: 1; margin-top: 6px; } }

/* ---------- Contact ---------- */
.contact { background: var(--ink); color: var(--paper); margin-top: 0; }
.contact-head { font-family: var(--disp); font-weight: 600; letter-spacing: -.03em; font-size: clamp(2.6rem, 9vw, 8rem); line-height: .94; padding-top: 70px; }
.contact-head .accent { color: var(--accent); font-family: var(--serif); font-style: italic; font-weight: 500; }
.contact-mail { display: inline-block; font-family: var(--disp); font-size: clamp(1.4rem, 4vw, 2.6rem); margin: 60px 0 40px; border-bottom: 2px solid var(--accent); padding-bottom: 6px; transition: color .3s, gap .3s; }
.contact-mail:hover { color: var(--accent); }
.socials { display: flex; gap: 26px; flex-wrap: wrap; font-family: var(--mono); font-size: .85rem; text-transform: uppercase; letter-spacing: .06em; padding-bottom: 80px; }
.socials a { opacity: .8; }
.socials a:hover { color: var(--accent); opacity: 1; }

/* ---------- Footer ---------- */
.footer { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 14px; padding: 24px clamp(20px, 5vw, 64px); font-family: var(--mono); font-size: .74rem; text-transform: uppercase; letter-spacing: .06em; background: var(--ink); color: var(--ink-soft); border-top: 1px solid rgba(242,239,230,.16); }
.footer a:hover { color: var(--accent); }

/* ---------- Reveal ---------- */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .8s cubic-bezier(.16,1,.3,1), transform .8s cubic-bezier(.16,1,.3,1); }
.reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
  .ticker-row, .ast, .status i { animation: none; }
  .hero-title .hl { transform: none; }
}
