/* ===========================================================
   danorosz.com - bold & dark
   EB Garamond (display) + Lato (body). Petrol teal + brass on near-black.
   =========================================================== */
:root{
  --bg:#0a1316;
  --bg-2:#0e1c20;
  --surface:rgba(255,255,255,.035);
  --surface-2:rgba(255,255,255,.06);
  --border:rgba(140,200,198,.16);
  --border-strong:rgba(140,200,198,.32);
  --ink:#e9f1f0;
  --muted:#9bb0b0;
  --teal:#3fd6c4;          /* bright accent on dark */
  --teal-deep:#0f4c52;
  --brass:#d0aa6a;
  --maxw:1080px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family:"Lato",system-ui,sans-serif;
  background:var(--bg);
  color:var(--ink);
  line-height:1.65;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3{ font-family:"EB Garamond",Georgia,serif; font-weight:600; line-height:1.12; }
a{ color:var(--teal); }
::selection{ background:rgba(63,214,196,.25); }

.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 26px; }
.narrow{ max-width:780px; }

/* ---- scroll reveal ---- */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .7s ease, transform .7s ease; }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ .reveal{ opacity:1; transform:none; transition:none; } html{ scroll-behavior:auto; } }

/* ---- nav ---- */
.nav{
  position:sticky; top:0; z-index:30;
  background:rgba(10,19,22,.72);
  backdrop-filter:saturate(160%) blur(12px);
  border-bottom:1px solid var(--border);
}
.nav-inner{ display:flex; align-items:center; justify-content:space-between; height:64px; }
.brand{ font-family:"EB Garamond",serif; font-size:1.4rem; font-weight:600; color:var(--ink); text-decoration:none; letter-spacing:.01em; }
.brand:hover{ color:var(--teal); }
.links{ display:flex; gap:30px; }
.links a{ color:var(--muted); text-decoration:none; font-size:.95rem; position:relative; transition:color .2s ease; }
.links a:hover{ color:var(--ink); }
.links a::after{ content:""; position:absolute; left:0; right:0; bottom:-7px; height:2px;
  background:linear-gradient(90deg,var(--teal),var(--brass)); transform:scaleX(0); transform-origin:left; transition:transform .25s ease; }
.links a:hover::after{ transform:scaleX(1); }

/* ---- hero ---- */
.hero{
  position:relative;
  padding:120px 0 110px;
  overflow:hidden;
  border-bottom:1px solid var(--border);
}
.hero::before{
  content:""; position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(60% 75% at 18% 8%, rgba(63,214,196,.20), transparent 60%),
    radial-gradient(50% 60% at 92% 90%, rgba(208,170,106,.13), transparent 60%),
    linear-gradient(180deg, #0c181b, #0a1316);
}
.hero::after{
  content:""; position:absolute; left:0; right:0; bottom:0; height:1px;
  background:linear-gradient(90deg, transparent, var(--brass), transparent);
}
.hero .wrap{ position:relative; z-index:1; }
.eyebrow{
  text-transform:uppercase; letter-spacing:.34em; font-size:.78rem; font-weight:700;
  color:var(--teal); margin:0 0 26px;
}
.haiku{
  font-size:clamp(2.4rem,6.2vw,4.6rem);
  font-weight:600; line-height:1.08; margin:0 0 26px;
  color:#fff; letter-spacing:.005em;
}
.haiku .l{ display:block; }
.haiku .l:nth-child(2){ color:var(--ink); }
.haiku .accent{ font-style:italic; color:transparent;
  background:linear-gradient(92deg,var(--teal),#7fe9db 60%,var(--brass));
  -webkit-background-clip:text; background-clip:text; }
.lede{ font-size:1.18rem; color:var(--muted); max-width:62ch; margin:0 0 34px; }
.cta-row{ display:flex; gap:14px; flex-wrap:wrap; }
.meta{ margin-top:34px; color:#7d9494; font-size:.9rem; letter-spacing:.06em; text-transform:uppercase; }

.btn{
  display:inline-flex; align-items:center; gap:8px;
  padding:13px 26px; border-radius:8px; text-decoration:none; font-weight:700; font-size:.95rem;
  transition:transform .14s ease, box-shadow .25s ease, background .25s ease, color .2s ease, border-color .2s ease;
}
.btn:active{ transform:translateY(1px); }
.btn-solid{
  color:#06201f; background:linear-gradient(96deg,var(--teal),#69e6d6);
  box-shadow:0 8px 30px rgba(63,214,196,.28);
}
.btn-solid:hover{ box-shadow:0 10px 38px rgba(63,214,196,.42); }
.btn-ghost{ color:var(--ink); border:1.5px solid var(--border-strong); }
.btn-ghost:hover{ border-color:var(--teal); color:var(--teal); }

/* ---- bands ---- */
.band{ padding:90px 0; border-bottom:1px solid var(--border); position:relative; }
.band.alt{ background:var(--bg-2); }
.band h2{ font-size:2.3rem; margin:0 0 30px; color:#fff; position:relative; padding-bottom:12px; }
.band h2::after{ content:""; position:absolute; left:0; bottom:0; width:54px; height:3px;
  background:linear-gradient(90deg,var(--teal),var(--brass)); border-radius:2px; }
.band p{ font-size:1.07rem; color:#c2d2d1; }

/* ---- cards ---- */
.cards{ display:grid; grid-template-columns:repeat(2,1fr); gap:22px; margin-bottom:40px; }
.card{
  background:var(--surface); border:1px solid var(--border); border-radius:16px; padding:28px;
  position:relative; transition:transform .25s ease, border-color .25s ease, background .25s ease;
}
.card::before{
  content:""; position:absolute; inset:0; border-radius:16px; padding:1px;
  background:linear-gradient(135deg, rgba(63,214,196,.5), transparent 40%);
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude; opacity:0; transition:opacity .25s ease;
}
.card:hover{ transform:translateY(-4px); border-color:var(--border-strong); background:var(--surface-2); }
.card:hover::before{ opacity:1; }
.card h3{ margin:0 0 10px; font-size:1.4rem; color:var(--teal); }
.card p{ margin:0; color:var(--muted); font-size:1rem; }

/* ---- skills ---- */
.skills{ display:flex; flex-wrap:wrap; gap:11px; }
.skills span{
  background:rgba(63,214,196,.08); color:#bfe9e2; border:1px solid var(--border);
  border-radius:999px; padding:7px 16px; font-size:.86rem; font-weight:700;
  transition:border-color .2s ease, color .2s ease;
}
.skills span:hover{ border-color:var(--teal); color:#fff; }

/* ---- experience ---- */
.job{ padding:26px 0; border-bottom:1px solid var(--border); }
.job:last-child{ border-bottom:0; }
.job-head{ display:flex; justify-content:space-between; align-items:baseline; gap:16px; flex-wrap:wrap; }
.job-org{ font-family:"EB Garamond",serif; font-size:1.4rem; font-weight:600; color:#fff; }
.job-when{ color:var(--muted); font-size:.9rem; white-space:nowrap; }
.job-pos{ color:var(--teal); font-weight:700; margin:3px 0 10px; font-size:1rem; }
.job ul{ margin:0; padding-left:20px; }
.job li{ margin-bottom:7px; color:#c2d2d1; }
.job li::marker{ color:var(--brass); }

/* ---- contact / request form ---- */
.contact-lede{ margin-bottom:30px; }
.contact-form{ display:grid; gap:18px; max-width:600px; }
.field{ display:grid; gap:7px; }
.field label{ font-weight:700; font-size:.88rem; color:var(--ink); }
.field input,.field textarea{
  font:inherit; padding:13px 15px; border:1.5px solid var(--border); border-radius:10px;
  background:rgba(255,255,255,.03); color:var(--ink); transition:border-color .15s ease, box-shadow .15s ease;
}
.field input::placeholder,.field textarea::placeholder{ color:#6f8888; }
.field input:focus,.field textarea:focus{ outline:none; border-color:var(--teal); box-shadow:0 0 0 3px rgba(63,214,196,.16); }
.contact-form .btn-solid{ justify-self:start; }
.hp{ position:absolute; left:-9999px; width:1px; height:1px; overflow:hidden; }
.form-note{ margin:2px 0 0; font-size:.95rem; min-height:1.2em; }
.form-note.ok{ color:var(--teal); }
.form-note.err{ color:#ff8a7a; }

/* ---- footer ---- */
.foot{ background:#070f11; color:#7d9494; }
.foot .wrap{ display:flex; justify-content:space-between; align-items:center; padding-top:26px; padding-bottom:26px; font-size:.9rem; }
.foot a{ color:#7d9494; text-decoration:none; }
.foot a:hover{ color:var(--brass); }

/* ---- responsive ---- */
@media (max-width:720px){
  .links{ display:none; }
  .cards{ grid-template-columns:1fr; }
  .hero{ padding:84px 0 70px; }
  .band{ padding:62px 0; }
}
