/* Yasya Bernies — personal site. Shared styles. */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300..600;1,9..144,300..500&family=Hanken+Grotesk:wght@400;500;600&display=swap');

:root{
  --paper:#FAF6EF;
  --paper-2:#F3ECDF;
  --paper-3:#ECE3D3;
  --ink:#221D17;
  --ink-soft:#6A6053;
  --ink-faint:#938979;
  --accent:#BC5A3C;
  --accent-deep:#8C3F27;
  --line:rgba(34,29,23,.12);
  --line-soft:rgba(34,29,23,.07);
  --live-bg:#E2EAD9; --live-tx:#3D5A37;
  --prog-bg:#F4E6CB; --prog-tx:#8A6022;
  --soon-bg:#EAE2D4; --soon-tx:#6A6053;
  --display:"Fraunces",Georgia,serif;
  --body:"Hanken Grotesk",-apple-system,sans-serif;
  --maxw:780px;
  --nav-h:66px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--body);
  font-size:18px;
  line-height:1.7;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
.hero h1,.building h2,.card h3,.teaser p,.contact h2,.phero h1,.era h3,.value h4,.sec-head h2,.brand{
  font-optical-sizing:auto;
}
a{color:inherit;text-decoration:none}
img,video{max-width:100%;display:block}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}

/* ---------- nav ---------- */
.nav{
  position:sticky;top:0;z-index:50;
  height:var(--nav-h);
  background:rgba(250,246,239,.82);
  backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--line-soft);
}
.nav .wrap{height:100%;display:flex;align-items:center;justify-content:space-between;gap:18px}
.brand{font-family:var(--display);font-weight:600;font-size:19px;letter-spacing:.005em;color:var(--ink)}
.brand span{color:inherit;font-weight:inherit}
.nav-links{display:flex;align-items:center;gap:26px}
.nav-links a{font-size:15px;color:var(--ink-soft);transition:color .2s}
.nav-links a:hover{color:var(--ink)}
.nav-links .btn-hi{
  font-family:var(--body);font-size:14.5px;font-weight:600;letter-spacing:.01em;
  color:#fff;background:var(--ink);
  padding:10px 20px;border-radius:999px;border:1px solid var(--ink);
  transition:background .2s,transform .2s,box-shadow .2s;
}
.nav-links .btn-hi:hover{color:#fff;background:#000;transform:translateY(-1px);box-shadow:0 4px 14px rgba(34,29,23,.18)}

/* anchor offset so headings clear the sticky nav (fixes the iOS jump) */
#contact,#work,#about,[id]{scroll-margin-top:calc(var(--nav-h) + 18px)}

/* ---------- shared section bits ---------- */
.eyebrow{
  font-size:13px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--accent);font-weight:500;margin-bottom:18px;
}
.lead{font-size:21px;color:var(--ink-soft);line-height:1.5}
section{padding:0}
.rule{height:1px;background:var(--line-soft);border:0;margin:0}

/* sections stack as one clean column (heading, then body) */
.split{display:block}
.split .split-head{margin-bottom:16px}
.split .split-body{max-width:none}
.split .split-body > :last-child{margin-bottom:0}
.split-head h2{font-family:var(--display);font-weight:400;font-size:clamp(28px,3.8vw,40px);
  letter-spacing:-.01em;line-height:1.08;color:var(--ink);margin:0}
.block.split{max-width:none;padding:30px 0}
.block.split .split-head{margin-bottom:12px}
.block.split .split-head .label{margin-bottom:0}

/* ---------- hero (home) ---------- */
.hero{padding:64px 0 18px}
.hero-grid{display:block}
.hero .kick{font-size:14.5px;letter-spacing:.04em;color:var(--ink-faint);margin-bottom:24px}
.hero h1{
  font-family:var(--display);font-weight:400;
  font-size:clamp(42px,5.6vw,72px);line-height:1.03;letter-spacing:-.015em;
  margin-bottom:22px;
}
.hero h1 em{font-style:italic;color:var(--accent)}
.hero .tag{font-family:var(--display);font-style:italic;font-weight:300;
  font-size:clamp(22px,2.6vw,28px);line-height:1.4;color:var(--ink);max-width:22em;
  text-wrap:balance;margin-bottom:28px}
.hero p.intro{font-size:19px;color:var(--ink-soft);max-width:none}
.hero p.intro strong{color:var(--ink);font-weight:500}
.hero-photo{display:none}
/* hand-drawn macron for the Enso wordmark (display font misplaces the glyph) */
.omac{display:inline-block;position:relative;line-height:1}
.omac::after{content:"";position:absolute;left:50%;transform:translateX(-50%);
  bottom:calc(1ex + 0.2em);width:0.5em;height:0.06em;background:currentColor;border-radius:.04em}
.about-photo{margin:30px 0 4px}
.about-photo img{width:100%;max-width:260px;border-radius:16px;border:1px solid var(--line)}
.hero-photo img{width:100%;max-width:300px;max-height:380px;object-fit:cover;object-position:50% 30%;
  border-radius:18px;border:1px solid var(--line)}

/* ---------- building section ---------- */
.building{padding:64px 0 26px}
.building h2{font-family:var(--display);font-weight:400;font-size:clamp(30px,4.2vw,42px);
  letter-spacing:-.01em;margin-bottom:20px;color:var(--ink)}
.building p{max-width:none;color:var(--ink-soft);font-size:19px}

/* ---------- project cards ---------- */
.cards{padding:38px 0 64px;display:grid;grid-template-columns:1fr 1fr;gap:20px}
.card{
  display:block;background:var(--paper-2);border:1px solid var(--line);
  border-radius:16px;padding:30px 30px 26px;cursor:pointer;
  box-shadow:0 1px 2px rgba(34,29,23,.04),0 6px 20px rgba(34,29,23,.05);
  transition:transform .22s ease,border-color .22s,background .22s,box-shadow .22s;
  position:relative;
}
.card:hover{transform:translateY(-4px);border-color:var(--accent);background:var(--paper-3);
  box-shadow:0 12px 34px rgba(34,29,23,.13)}
.card .pill{margin-bottom:18px}
.card h3{font-family:var(--display);font-weight:500;font-size:30px;letter-spacing:-.01em;margin-bottom:12px;color:var(--ink)}
.card .ctag{font-family:var(--body);font-style:normal;font-weight:400;font-size:17.5px;
  color:var(--ink-soft);line-height:1.55;max-width:40ch}
.card-foot{margin-top:24px;display:flex;flex-wrap:wrap;align-items:center;gap:22px}
.card .more{font-size:15px;font-weight:600;color:var(--accent);
  display:inline-flex;align-items:center;gap:7px;transition:gap .2s}
.card:hover .more{gap:12px}
/* whole-card click target (opens the description page) */
.card-link::after{content:"";position:absolute;inset:0;z-index:1;border-radius:16px}
/* a real second action for live apps: jump straight to the app */
.card .visit{position:relative;z-index:2;font-size:14.5px;font-weight:600;color:var(--ink);
  display:inline-flex;align-items:center;gap:6px;
  border-bottom:1.5px solid var(--accent);padding-bottom:2px;transition:color .2s,gap .2s}
.card .visit:hover{color:var(--accent);gap:9px}

.pill{
  display:inline-block;font-size:12.5px;font-weight:500;letter-spacing:.04em;
  padding:5px 12px;border-radius:999px;
}
.pill.live{background:var(--live-bg);color:var(--live-tx)}
.pill.prog{background:var(--prog-bg);color:var(--prog-tx)}
.pill.soon{background:var(--soon-bg);color:var(--soon-tx)}

/* ---------- about teaser ---------- */
.teaser{padding:60px 0;border-top:1px solid var(--line-soft)}
.teaser h2{font-family:var(--display);font-weight:400;font-size:clamp(30px,4.2vw,42px);
  letter-spacing:-.01em;margin-bottom:18px;color:var(--ink)}
.teaser p{font-size:19px;color:var(--ink-soft);line-height:1.7;margin-bottom:22px}
.teaser a.link{font-size:15px;font-weight:600;color:var(--accent);
  display:inline-flex;align-items:center;gap:8px;transition:gap .2s}
.teaser a.link:hover{gap:13px}

/* ---------- contact ---------- */
.contact{padding:72px 0 64px;border-top:1px solid var(--line);background:var(--paper-2)}
.contact h2{font-family:var(--display);font-weight:400;font-size:clamp(32px,4.6vw,46px);
  letter-spacing:-.015em;margin-bottom:20px;color:var(--ink)}
.contact p{font-size:20px;color:var(--ink-soft);max-width:none;margin-bottom:30px}
.contact .actions{display:flex;flex-wrap:wrap;gap:14px}
.actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:28px}
.phero .lead{max-width:none}
.lnk{
  font-size:16px;font-weight:500;padding:13px 26px;border-radius:999px;
  border:1px solid var(--ink);color:var(--ink);transition:all .2s;
}
.lnk.solid{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.lnk:hover{transform:translateY(-2px)}
.lnk.solid:hover{background:var(--accent);border-color:var(--accent)}
.lnk.ghost:hover{border-color:var(--accent);color:var(--accent)}

/* ---------- footer ---------- */
.foot{padding:34px 0 48px;border-top:1px solid var(--line-soft)}
.foot p{font-size:14.5px;color:var(--ink-faint)}
.foot em{font-style:italic}

/* ---------- project page ---------- */
.back{display:inline-flex;align-items:center;gap:8px;font-size:14.5px;color:var(--ink-soft);
  margin-bottom:30px;transition:gap .2s,color .2s}
.back:hover{gap:12px;color:var(--ink)}
.phero{padding:54px 0 14px}
.phero .pill{margin-bottom:22px}
.phero h1{font-family:var(--display);font-weight:400;font-size:clamp(40px,6.5vw,68px);
  letter-spacing:-.015em;line-height:1.04;margin-bottom:20px}
.phero .tag{font-family:var(--display);font-style:italic;font-weight:300;
  font-size:clamp(21px,3vw,28px);color:var(--accent-deep);max-width:30ch}

.block{padding:30px 0;max-width:none}
.block .label{font-size:13px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-faint);font-weight:500;margin-bottom:12px}
.block p{font-size:19px;color:var(--ink-soft);margin-bottom:16px}
.block p:last-child{margin-bottom:0}
.block strong{font-weight:600;color:var(--ink)}

.cta-row{padding:28px 0 80px}
.note{font-size:14.5px;color:var(--ink-faint);font-style:italic;margin-bottom:18px}
/* demo video shown high on the project page */
.phero-demo{margin:8px 0 30px;max-width:660px;border:1px solid var(--line);
  border-radius:14px;overflow:hidden;background:var(--paper-3)}
.phero-demo video{width:100%;max-height:74vh;object-fit:contain;display:block}

/* media slot (placeholder until real photo/video dropped in) */
.media{margin:26px 0 8px;border:1.5px dashed var(--line);border-radius:14px;
  background:var(--paper-2);padding:40px 28px;text-align:center}
.media .mlabel{font-size:14px;color:var(--ink-faint);line-height:1.6}
.media .mlabel code{font-family:ui-monospace,monospace;font-size:13px;
  background:var(--paper-3);padding:2px 7px;border-radius:5px;color:var(--ink-soft)}
.media.filled{border-style:solid;border-color:var(--line);padding:0;overflow:hidden;background:transparent}
.media.filled video,.media.filled img{width:100%;display:block}
.media figcaption{font-size:14px;color:var(--ink-faint);padding:12px 4px 2px;text-align:left}
/* photo with an elegant caption set over the image */
.media.overlay{position:relative;max-width:560px}
.media.overlay figcaption{position:absolute;left:0;right:0;bottom:0;padding:46px 22px 16px;
  margin:0;color:#fff;font-size:14px;font-style:italic;letter-spacing:.01em;
  background:linear-gradient(to top,rgba(18,14,10,.74),rgba(18,14,10,0))}

/* ---------- about page ---------- */
.timeline{padding:18px 0 10px}
.era{padding:34px 0;border-top:1px solid var(--line-soft);display:grid;
  grid-template-columns:170px 1fr;gap:30px}
.era:first-child{border-top:0}
.era .when{font-size:14.5px;color:var(--ink-faint);font-weight:500;padding-top:4px}
.era h3{font-family:var(--display);font-weight:500;font-size:26px;margin-bottom:4px}
.era .role{font-size:16px;color:var(--ink-soft);margin-bottom:16px}
.era .subrole{font-family:var(--body);font-size:13px;font-weight:600;letter-spacing:.12em;
  text-transform:uppercase;color:var(--accent);margin:22px 0 12px}
.era .subrole:first-of-type{margin-top:6px}
.era ul{list-style:none;display:flex;flex-direction:column;gap:13px}
.era li{font-size:17px;color:var(--ink);padding-left:20px;position:relative;line-height:1.6}
.era li::before{content:"";position:absolute;left:0;top:11px;width:6px;height:6px;
  border-radius:50%;background:var(--accent);opacity:.65}
.era li strong{font-weight:500}
.education{padding:6px 0 24px}
.edu-item .edu-school{font-family:var(--display);font-weight:500;font-size:21px;color:var(--ink);display:block}
.edu-item .edu-degree{font-size:15.5px;color:var(--ink-soft);display:block;margin-top:3px}
.edu-item.lead{padding-bottom:20px;margin-bottom:20px;border-bottom:1px solid var(--line-soft)}
.edu-item.lead .edu-school{font-size:31px;letter-spacing:-.01em}
.edu-item.lead .edu-degree{font-size:17px;color:var(--accent-deep);font-weight:600;margin-top:5px}

.values{padding:20px 0 10px;display:grid;grid-template-columns:1fr 1fr;gap:26px}
.value h4{font-family:var(--display);font-weight:500;font-size:21px;margin-bottom:9px}
.value p{font-size:16.5px;color:var(--ink-soft);line-height:1.6}
.langs{padding:34px 0;border-top:1px solid var(--line-soft);font-size:18px;
  color:var(--ink-soft);max-width:none}
.langs strong{color:var(--ink);font-weight:500}

/* page intro heading for about/how-i-work blocks */
.sec-head{padding:50px 0 6px}
.sec-head h2{font-family:var(--display);font-weight:400;font-size:clamp(30px,4.2vw,42px);
  letter-spacing:-.01em;margin-bottom:14px;color:var(--ink)}
.sec-head p{color:var(--ink-soft);max-width:none;font-size:18px}

/* staggered load */
@media (prefers-reduced-motion:no-preference){
  .fade{opacity:0;transform:translateY(14px);animation:fu .7s cubic-bezier(.2,.7,.2,1) forwards}
  .d1{animation-delay:.05s}.d2{animation-delay:.14s}.d3{animation-delay:.23s}
  .d4{animation-delay:.32s}.d5{animation-delay:.41s}
  @keyframes fu{to{opacity:1;transform:none}}
}

/* ---------- responsive ---------- */
@media (max-width:900px){
  .hero-grid{grid-template-columns:1fr;gap:24px}
  .hero .tag{max-width:none}
  .hero p.intro{max-width:none}
  .hero-photo img{max-width:300px;max-height:340px}
}
@media (max-width:760px){
  body{font-size:16px;line-height:1.55}
  .wrap{padding:0 22px}
  .lead{font-size:17.5px;line-height:1.5}
  .about-photo{margin:18px 0 4px}
  .about-photo img{max-width:240px}
  .brand{font-size:17px}
  .nav-links{gap:15px}
  .nav-links a{font-size:14px}
  .nav-links .btn-hi{padding:9px 16px;font-size:13.5px}
  .split{grid-template-columns:1fr;gap:14px}
  .cards{grid-template-columns:1fr;gap:16px}
  .values{grid-template-columns:1fr;gap:20px}
  .era{grid-template-columns:1fr;gap:8px}
  .era .when{padding-top:0}
  .hero{padding:54px 0 14px}
}

/* ---------- waitlist (inline Netlify form) ---------- */
button.lnk{font-family:var(--body);cursor:pointer;line-height:1;-webkit-appearance:none;appearance:none}
.waitlist{margin-top:2px}
.waitlist-form{display:flex;flex-wrap:wrap;gap:10px;align-items:center;max-width:470px}
.waitlist-input{
  flex:1 1 240px;font-family:var(--body);font-size:16px;color:var(--ink);
  padding:12px 20px;border-radius:999px;border:1px solid var(--ink);
  background:var(--paper);transition:border-color .2s,box-shadow .2s;
}
.waitlist-input::placeholder{color:var(--ink-faint)}
.waitlist-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(188,90,60,.12)}
.waitlist-send{flex:0 0 auto}
.waitlist-msg{font-size:17px;color:var(--ink-soft);line-height:1.5;max-width:42ch}
.waitlist-msg.ok{color:var(--live-tx)}
.waitlist-msg.err{color:var(--accent-deep)}
.waitlist [hidden]{display:none}
