/* ============================================================
   MATEUSZFATEK.PL — "Atrament i złocenie" / "Ink & Gilding"
   Palette: ink black / antique gold / paper gray
   Type: Fraunces (display) · Manrope (body) · JetBrains Mono (data)
   ============================================================ */

:root{
  --ink:        #0a0a0e;
  --ink-2:      #0f0f16;
  --ink-3:      #15151f;
  --ink-4:      #1c1c28;
  --line:       rgba(201,162,39,.16);
  --line-soft:  rgba(233,230,222,.08);
  --gold:       #c9a227;
  --gold-2:     #e7d08a;
  --gold-deep:  #8d6f1c;
  --paper:      #e9e6de;
  --mist:       #9b988f;
  --mist-2:     #6e6c66;
  --danger:     #c0564a;
  --ok:         #7ba05b;
  --max:        1180px;
  --radius:     14px;
  --ease:       cubic-bezier(.22,.61,.2,1);
  --gild:       linear-gradient(100deg,#8d6f1c 0%,#c9a227 28%,#f3e3ae 50%,#c9a227 72%,#8d6f1c 100%);
}

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

body{
  background:var(--ink);
  color:var(--paper);
  font-family:'Manrope',system-ui,-apple-system,sans-serif;
  font-size:17px;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

::selection{ background:var(--gold); color:var(--ink); }

img{ max-width:100%; display:block; }
a{ color:var(--gold-2); text-decoration:none; transition:color .25s var(--ease); }
a:hover{ color:#fff; }

:focus-visible{ outline:2px solid var(--gold); outline-offset:3px; border-radius:3px; }

/* ---------- Language switching ---------- */
.l{ display:revert; }
body.lang-pl .en{ display:none !important; }
body.lang-en .pl{ display:none !important; }

/* ---------- Typography ---------- */
h1,h2,h3,.display{
  font-family:'Fraunces',Georgia,serif;
  font-weight:560;
  letter-spacing:-.015em;
  line-height:1.12;
  color:var(--paper);
}
.eyebrow{
  font-family:'JetBrains Mono',monospace;
  font-size:.72rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--gold);
  display:flex;
  align-items:center;
  gap:14px;
  margin-bottom:18px;
}
.eyebrow::before{
  content:'';
  width:34px; height:1px;
  background:var(--gild);
  flex:none;
}
.section-title{
  font-size:clamp(1.9rem,4vw,2.9rem);
  margin-bottom:14px;
}
.section-title em{
  font-style:italic;
  font-weight:430;
  background:var(--gild);
  background-size:200% auto;
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  animation:sheen 7s linear infinite;
}
@keyframes sheen{ to{ background-position:200% center; } }
.section-lead{
  color:var(--mist);
  max-width:62ch;
  font-size:1.04rem;
}

/* ---------- Layout ---------- */
.wrap{ width:min(var(--max),calc(100% - 48px)); margin-inline:auto; }
section{ padding:104px 0; position:relative; }
section.tight{ padding:72px 0; }

/* gilded page-edge divider between sections */
.gild-edge{
  height:1px;
  width:100%;
  background:linear-gradient(90deg,transparent,rgba(201,162,39,.35) 18%,rgba(243,227,174,.6) 50%,rgba(201,162,39,.35) 82%,transparent);
  opacity:.5;
}

/* ---------- Reveal on scroll ---------- */
.rv{ opacity:0; transform:translateY(26px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.rv.in{ opacity:1; transform:none; }
.rv.d1{ transition-delay:.08s } .rv.d2{ transition-delay:.16s }
.rv.d3{ transition-delay:.24s } .rv.d4{ transition-delay:.32s }

/* ---------- Navigation ---------- */
.nav{
  position:fixed; inset:0 0 auto 0; z-index:90;
  transition:background .35s,border-color .35s,backdrop-filter .35s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(10,10,14,.82);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border-bottom-color:var(--line);
}
.nav-inner{
  display:flex; align-items:center; justify-content:space-between;
  height:74px;
}
.brand{
  display:flex; align-items:center; gap:12px;
  font-family:'Fraunces',serif; font-size:1.12rem; color:var(--paper);
}
.brand:hover{ color:var(--paper); }
.monogram{
  width:40px;height:40px;flex:none;
  border:1px solid var(--gold);
  border-radius:50%;
  display:grid;place-items:center;
  font-family:'Fraunces',serif;
  font-size:.92rem; font-weight:600;
  color:var(--gold-2);
  background:radial-gradient(circle at 30% 25%,rgba(201,162,39,.22),transparent 70%);
}
.nav-links{ display:flex; align-items:center; gap:26px; list-style:none; }
.nav-links a{
  font-size:.86rem; font-weight:600; letter-spacing:.02em; color:var(--mist);
  position:relative; padding:4px 0;
}
.nav-links a::after{
  content:''; position:absolute; left:0; bottom:-2px;
  width:100%; height:1px; background:var(--gild);
  transform:scaleX(0); transform-origin:right;
  transition:transform .35s var(--ease);
}
.nav-links a:hover{ color:var(--paper); }
.nav-links a:hover::after{ transform:scaleX(1); transform-origin:left; }

.lang-toggle{
  font-family:'JetBrains Mono',monospace;
  font-size:.74rem; letter-spacing:.08em;
  border:1px solid var(--line);
  background:rgba(201,162,39,.06);
  color:var(--paper);
  border-radius:999px;
  padding:7px 14px;
  cursor:pointer;
  transition:border-color .3s,background .3s;
}
.lang-toggle:hover{ border-color:var(--gold); background:rgba(201,162,39,.14); }
.lang-toggle b{ color:var(--gold-2); font-weight:700; }

.burger{
  display:none;
  background:none;border:1px solid var(--line);border-radius:10px;
  width:42px;height:42px;cursor:pointer;color:var(--paper);
  font-size:1.05rem;
}

/* ---------- Hero ---------- */
.hero{
  min-height:100svh;
  display:flex; align-items:center;
  padding:150px 0 90px;
  position:relative;
  isolation:isolate;
  overflow:hidden;
}
#glyphs{
  position:absolute; inset:0; z-index:-2;
}
.hero-glow{
  position:absolute; z-index:-1; inset:0;
  background:
    radial-gradient(820px 480px at 78% 30%,rgba(201,162,39,.13),transparent 64%),
    radial-gradient(640px 420px at 12% 86%,rgba(201,162,39,.07),transparent 60%);
  pointer-events:none;
}
.hero-grid{
  display:grid;
  grid-template-columns:minmax(0,1.18fr) minmax(0,.82fr);
  gap:64px;
  align-items:center;
}
.hero-name{
  font-family:'JetBrains Mono',monospace;
  color:var(--mist);
  font-size:.86rem;
  letter-spacing:.42em;
  text-transform:uppercase;
  margin-bottom:22px;
}
.hero-name b{ color:var(--gold-2); font-weight:600; }
.hero h1{
  font-size:clamp(2.6rem,6.2vw,4.6rem);
  font-weight:480;
}
.hero h1 .static{ display:block; color:var(--paper); }
.roles{
  display:block;
  min-height:1.18em;
  font-style:italic;
  font-weight:560;
  background:var(--gild);
  background-size:220% auto;
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent;
  animation:sheen 8s linear infinite;
}
.caret{
  display:inline-block; width:2px; height:.9em;
  background:var(--gold-2);
  margin-left:6px; vertical-align:-0.08em;
  animation:blink 1s steps(1) infinite;
}
@keyframes blink{ 50%{ opacity:0; } }
.hero-sub{
  margin-top:26px;
  color:var(--mist);
  max-width:56ch;
  font-size:1.08rem;
}
.hero-cta{ margin-top:38px; display:flex; gap:16px; flex-wrap:wrap; }

.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-weight:700; font-size:.93rem;
  padding:14px 26px;
  border-radius:999px;
  border:1px solid transparent;
  cursor:pointer;
  transition:transform .3s var(--ease),box-shadow .3s,background .3s,border-color .3s,color .3s;
}
.btn:active{ transform:scale(.97); }
.btn-gold{
  background:var(--gild);
  background-size:200% auto;
  color:#161103;
}
.btn-gold:hover{ background-position:90% center; color:#000; box-shadow:0 8px 32px rgba(201,162,39,.32); transform:translateY(-2px); }
.btn-ghost{
  border-color:var(--line);
  color:var(--paper);
  background:rgba(233,230,222,.03);
}
.btn-ghost:hover{ border-color:var(--gold); color:var(--gold-2); transform:translateY(-2px); }

.hero-chips{ margin-top:42px; display:flex; flex-wrap:wrap; gap:9px; }
.chip{
  font-family:'JetBrains Mono',monospace;
  font-size:.7rem; letter-spacing:.06em;
  color:var(--mist);
  border:1px solid var(--line-soft);
  border-radius:999px;
  padding:6px 13px;
  background:rgba(233,230,222,.02);
}

/* portrait */
.portrait{
  position:relative;
  max-width:420px;
  margin-inline:auto;
}
.portrait-frame{
  position:relative;
  border-radius:18px;
  overflow:hidden;
  border:1px solid var(--line);
  box-shadow:0 30px 80px rgba(0,0,0,.55);
  transform:rotate(1.2deg);
  transition:transform .6s var(--ease);
}
.portrait:hover .portrait-frame{ transform:rotate(0deg) scale(1.015); }
.portrait-frame::after{
  content:'';
  position:absolute; inset:0;
  background:linear-gradient(180deg,transparent 60%,rgba(10,10,14,.55));
  pointer-events:none;
}
.portrait-frame img{ width:100%; height:auto; }
.portrait-rule{
  position:absolute; z-index:-1;
  inset:-16px -16px auto auto;
  width:78%; height:78%;
  border:1px solid var(--gold);
  border-radius:18px;
  opacity:.5;
  transform:rotate(-1.6deg);
}
.portrait-cap{
  position:absolute; left:-24px; bottom:26px;
  background:rgba(10,10,14,.86);
  backdrop-filter:blur(8px);
  border:1px solid var(--line);
  border-radius:12px;
  padding:12px 18px;
  font-family:'JetBrains Mono',monospace;
  font-size:.72rem; letter-spacing:.1em;
  color:var(--gold-2);
}

.scroll-hint{
  position:absolute; left:50%; bottom:26px; transform:translateX(-50%);
  color:var(--mist-2);
  font-family:'JetBrains Mono',monospace; font-size:.68rem; letter-spacing:.3em;
  display:flex; flex-direction:column; align-items:center; gap:8px;
}
.scroll-hint::after{
  content:''; width:1px; height:42px;
  background:linear-gradient(180deg,var(--gold),transparent);
  animation:drip 2.1s var(--ease) infinite;
}
@keyframes drip{ 0%{transform:scaleY(0);transform-origin:top} 55%{transform:scaleY(1);transform-origin:top} 56%{transform-origin:bottom} 100%{transform:scaleY(0);transform-origin:bottom} }

/* ---------- Stats strip ---------- */
.stats{
  border-block:1px solid var(--line);
  background:linear-gradient(180deg,rgba(201,162,39,.05),rgba(201,162,39,.015));
  padding:46px 0;
}
.stats-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:34px;
}
.stat{ text-align:left; }
.stat .num{
  font-family:'Fraunces',serif;
  font-size:clamp(2rem,3.6vw,2.9rem);
  font-weight:560;
  color:var(--gold-2);
  font-variant-numeric:tabular-nums;
  line-height:1.05;
}
.stat .num sup{ font-size:.5em; color:var(--gold); }
.stat .lbl{
  margin-top:8px;
  color:var(--mist);
  font-size:.86rem;
  letter-spacing:.02em;
}

/* ---------- About ---------- */
.about-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:64px;
  align-items:start;
}
.about-copy p{ color:var(--mist); margin-bottom:18px; }
.about-copy p strong{ color:var(--paper); font-weight:700; }
.facets{ display:grid; gap:14px; }
.facet{
  border:1px solid var(--line-soft);
  background:var(--ink-2);
  border-radius:var(--radius);
  padding:22px 24px;
  display:flex; gap:18px; align-items:flex-start;
  transition:border-color .35s,transform .35s var(--ease),background .35s;
}
.facet:hover{ border-color:var(--line); transform:translateX(6px); background:var(--ink-3); }
.facet .glyph{
  font-family:'Fraunces',serif;
  font-style:italic;
  font-size:1.5rem;
  color:var(--gold);
  flex:none;
  width:38px;
  text-align:center;
}
.facet h3{ font-size:1.06rem; margin-bottom:4px; }
.facet p{ color:var(--mist); font-size:.92rem; line-height:1.6; }

/* ---------- Clients / translation ---------- */
.bg-2{ background:var(--ink-2); }
.client-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
  margin-top:54px;
}
.client-card{
  position:relative;
  border:1px solid var(--line-soft);
  background:var(--ink);
  border-radius:var(--radius);
  padding:30px 28px;
  overflow:hidden;
  transition:transform .4s var(--ease),border-color .4s,box-shadow .4s;
}
.client-card::before{
  content:'';
  position:absolute; inset:0 0 auto 0; height:2px;
  background:var(--gild);
  transform:scaleX(0); transform-origin:left;
  transition:transform .5s var(--ease);
}
.client-card:hover{ transform:translateY(-6px); border-color:var(--line); box-shadow:0 18px 48px rgba(0,0,0,.4); }
.client-card:hover::before{ transform:scaleX(1); }
.client-card .tag{
  font-family:'JetBrains Mono',monospace;
  font-size:.66rem; letter-spacing:.22em; text-transform:uppercase;
  color:var(--gold);
  margin-bottom:14px; display:block;
}
.client-card h3{ font-size:1.3rem; margin-bottom:10px; }
.client-card p{ color:var(--mist); font-size:.93rem; }

.domains{ margin-top:46px; display:flex; flex-wrap:wrap; gap:10px; }
.domains .chip{ font-size:.74rem; padding:8px 16px; }
.domains .chip:hover{ border-color:var(--gold); color:var(--gold-2); }

/* ---------- XL8TMS ---------- */
.xl8-grid{
  display:grid;
  grid-template-columns:minmax(0,.92fr) minmax(0,1.08fr);
  gap:60px;
  align-items:center;
  margin-top:20px;
}
.xl8-feats{ list-style:none; display:grid; gap:14px; margin-top:30px; }
.xl8-feats li{
  display:flex; gap:14px; color:var(--mist); font-size:.96rem;
}
.xl8-feats li::before{
  content:'§';
  font-family:'Fraunces',serif;
  color:var(--gold);
  flex:none;
}
.browser{
  border:1px solid var(--line);
  border-radius:16px;
  background:var(--ink-3);
  overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,.5);
  transform:perspective(1200px) rotateY(-4deg) rotateX(1.5deg);
  transition:transform .7s var(--ease);
}
.browser:hover{ transform:perspective(1200px) rotateY(0) rotateX(0); }
.browser-bar{
  display:flex; align-items:center; gap:8px;
  padding:12px 16px;
  border-bottom:1px solid var(--line-soft);
  background:var(--ink-4);
}
.dot{ width:10px;height:10px;border-radius:50%;background:var(--mist-2); }
.dot.g{ background:var(--gold); }
.browser-url{
  margin-left:10px;
  font-family:'JetBrains Mono',monospace;
  font-size:.7rem; color:var(--mist);
  background:var(--ink-2);
  border-radius:6px;
  padding:4px 12px;
  flex:1;
}
.browser-body{ padding:26px; min-height:300px; display:grid; gap:14px; }
.skeleton{
  border-radius:8px;
  background:linear-gradient(100deg,var(--ink-4) 35%,#232333 50%,var(--ink-4) 65%);
  background-size:300% 100%;
  animation:shimmer 2.6s linear infinite;
}
@keyframes shimmer{ to{ background-position:-300% 0; } }
.sk-row{ display:grid; grid-template-columns:2fr 1fr 1fr; gap:14px; }
.browser-note{
  text-align:center;
  font-family:'JetBrains Mono',monospace;
  font-size:.68rem; letter-spacing:.16em;
  color:var(--mist-2);
  padding:10px 0 2px;
}

/* ---------- Books ---------- */
.shelf{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:30px;
  margin-top:56px;
}
.book{
  display:grid; gap:18px;
}
.cover{
  aspect-ratio:2/3;
  border-radius:6px 12px 12px 6px;
  position:relative;
  background:
    radial-gradient(140% 90% at 80% 0%,rgba(201,162,39,.16),transparent 55%),
    linear-gradient(160deg,var(--ink-4),var(--ink-2) 60%,#0c0c12);
  border:1px solid var(--line);
  border-left:6px solid var(--gold-deep);
  box-shadow:0 24px 56px rgba(0,0,0,.5);
  padding:26px 22px;
  display:flex; flex-direction:column; justify-content:space-between;
  transition:transform .5s var(--ease),box-shadow .5s;
  overflow:hidden;
}
.book:hover .cover{ transform:translateY(-10px) rotate(-1.1deg); box-shadow:0 36px 76px rgba(0,0,0,.62),0 0 0 1px rgba(201,162,39,.25); }
.cover::after{
  content:'';
  position:absolute; top:0; bottom:0; left:6px; width:1px;
  background:rgba(243,227,174,.35);
  z-index:3;
}
.cover-img{
  position:absolute; inset:0; z-index:2;
  width:100%; height:100%;
  object-fit:cover;
  background:var(--ink-3);
}
.cover .series,.cover .title,.cover .author{ position:relative; z-index:1; }
.cover .series{
  font-family:'JetBrains Mono',monospace;
  font-size:.62rem; letter-spacing:.28em; text-transform:uppercase;
  color:var(--gold);
}
.cover .title{
  font-family:'Fraunces',serif;
  font-size:1.46rem;
  line-height:1.2;
  font-weight:560;
  color:var(--paper);
}
.cover .title em{ display:block; font-size:.92rem; color:var(--gold-2); margin-top:10px; font-weight:430; }
.cover .author{
  font-family:'JetBrains Mono',monospace;
  font-size:.68rem; letter-spacing:.3em; text-transform:uppercase;
  color:var(--mist);
}
.book-links{ display:flex; gap:10px; flex-wrap:wrap; }
.book-links a{
  font-size:.78rem; font-weight:700;
  border:1px solid var(--line);
  border-radius:999px;
  padding:7px 16px;
  color:var(--paper);
  transition:border-color .3s,color .3s,background .3s;
}
.book-links a:hover{ border-color:var(--gold); color:var(--gold-2); background:rgba(201,162,39,.07); }
.books-note{ margin-top:40px; color:var(--mist); font-size:.95rem; max-width:70ch; }
.books-note a{ border-bottom:1px solid var(--line); }

/* ---------- Blog ---------- */
.blog-head{ display:flex; justify-content:space-between; align-items:flex-end; gap:30px; flex-wrap:wrap; }
.blog-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
  margin-top:50px;
}
.post{
  border:1px solid var(--line-soft);
  border-radius:var(--radius);
  background:var(--ink);
  padding:28px;
  display:flex; flex-direction:column; gap:14px;
  transition:transform .4s var(--ease),border-color .4s;
  min-height:230px;
}
.post:hover{ transform:translateY(-6px); border-color:var(--line); }
.post time{
  font-family:'JetBrains Mono',monospace;
  font-size:.68rem; letter-spacing:.18em; color:var(--gold);
  text-transform:uppercase;
}
.post h3{ font-size:1.12rem; line-height:1.35; }
.post h3 a{ color:var(--paper); }
.post h3 a:hover{ color:var(--gold-2); }
.post p{ color:var(--mist); font-size:.9rem; flex:1; }
.post .more{ font-size:.82rem; font-weight:700; color:var(--gold-2); }
.blog-status{
  margin-top:22px;
  font-family:'JetBrains Mono',monospace;
  font-size:.7rem; color:var(--mist-2); letter-spacing:.08em;
}

/* ---------- Case studies ---------- */
.cs-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:22px; margin-top:54px; }
.cs-card{
  position:relative;
  border:1px solid var(--line-soft);
  border-radius:var(--radius);
  padding:34px 32px;
  background:linear-gradient(150deg,var(--ink-3),var(--ink-2));
  overflow:hidden;
  transition:transform .45s var(--ease),border-color .45s;
  display:block;
  color:var(--paper);
}
.cs-card:hover{ transform:translateY(-6px); border-color:var(--gold); color:var(--paper); }
.cs-card .idx{
  position:absolute; right:18px; top:6px;
  font-family:'Fraunces',serif; font-style:italic;
  font-size:5rem; color:rgba(201,162,39,.1);
  pointer-events:none;
}
.cs-card .tag{ font-family:'JetBrains Mono',monospace; font-size:.64rem; letter-spacing:.24em; text-transform:uppercase; color:var(--gold); }
.cs-card h3{ font-size:1.34rem; margin:12px 0 10px; }
.cs-card p{ color:var(--mist); font-size:.93rem; }
.cs-card .more{ display:inline-block; margin-top:18px; font-weight:700; font-size:.85rem; color:var(--gold-2); }
.cs-card.coming{
  border-style:dashed;
  display:flex; align-items:center; justify-content:center;
  text-align:center; min-height:220px;
  color:var(--mist-2);
  font-family:'JetBrains Mono',monospace; font-size:.8rem; letter-spacing:.12em;
}

/* case study article page */
.article{ padding:170px 0 90px; max-width:820px; margin-inline:auto; }
.article .eyebrow{ justify-content:flex-start; }
.article h1{ font-size:clamp(2.1rem,4.6vw,3.3rem); margin-bottom:24px; }
.article .meta{
  display:flex; flex-wrap:wrap; gap:10px; margin:26px 0 44px;
}
.article h2{ font-size:1.5rem; margin:46px 0 16px; }
.article p{ color:var(--mist); margin-bottom:18px; }
.article ul{ color:var(--mist); margin:0 0 18px 22px; }
.article ul li{ margin-bottom:8px; }
.article strong{ color:var(--paper); }
.backlink{
  font-family:'JetBrains Mono',monospace; font-size:.74rem; letter-spacing:.14em;
  color:var(--mist);
}
.backlink:hover{ color:var(--gold-2); }

/* ---------- Contact ---------- */
.contact-grid{
  display:grid;
  grid-template-columns:minmax(0,.85fr) minmax(0,1.15fr);
  gap:64px;
  align-items:start;
}
.contact-info p{ color:var(--mist); margin-bottom:22px; }
.contact-rows{ display:grid; gap:16px; margin-top:8px; }
.contact-row{
  display:flex; gap:16px; align-items:baseline;
  border-bottom:1px solid var(--line-soft);
  padding-bottom:14px;
}
.contact-row .k{
  font-family:'JetBrains Mono',monospace; font-size:.68rem;
  letter-spacing:.2em; text-transform:uppercase; color:var(--gold);
  width:92px; flex:none;
}
.contact-row .v{ color:var(--paper); font-size:.96rem; }

form{ display:grid; gap:16px; }
.fields-2{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
label{ display:grid; gap:8px; font-size:.8rem; font-weight:700; letter-spacing:.04em; color:var(--mist); }
input,textarea{
  font:inherit;
  background:var(--ink-2);
  border:1px solid var(--line-soft);
  border-radius:10px;
  color:var(--paper);
  padding:14px 16px;
  transition:border-color .3s,box-shadow .3s;
}
input:focus,textarea:focus{
  outline:none;
  border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(201,162,39,.14);
}
textarea{ min-height:150px; resize:vertical; }
.form-msg{ font-size:.9rem; display:none; padding:14px 18px; border-radius:10px; }
.form-msg.ok{ display:block; background:rgba(123,160,91,.1); border:1px solid rgba(123,160,91,.4); color:#b8d49c; }
.form-msg.err{ display:block; background:rgba(192,86,74,.1); border:1px solid rgba(192,86,74,.4); color:#e0a49c; }
.hp{ position:absolute; left:-9999px; opacity:0; height:0; overflow:hidden; }

/* ---------- Footer ---------- */
footer{
  border-top:1px solid var(--line);
  padding:48px 0 40px;
  background:var(--ink-2);
}
.foot{
  display:flex; justify-content:space-between; gap:24px; flex-wrap:wrap;
  color:var(--mist-2); font-size:.84rem;
}
.foot a{ color:var(--mist); }
.foot a:hover{ color:var(--gold-2); }
.foot .sep{ opacity:.4; margin:0 8px; }

/* ---------- Mobile ---------- */
@media (max-width:1020px){
  .hero-grid{ grid-template-columns:1fr; gap:54px; }
  .portrait{ max-width:340px; }
  .about-grid,.xl8-grid,.contact-grid{ grid-template-columns:1fr; gap:48px; }
  .client-grid,.shelf,.blog-grid{ grid-template-columns:repeat(2,1fr); }
  .stats-grid{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:760px){
  body{ font-size:16px; }
  section{ padding:78px 0; }
  .nav-links{
    position:fixed; inset:74px 0 auto 0;
    flex-direction:column; align-items:flex-start;
    background:rgba(10,10,14,.97);
    border-bottom:1px solid var(--line);
    padding:22px 28px 30px;
    gap:18px;
    display:none;
  }
  .nav-links.open{ display:flex; }
  .burger{ display:block; }
  .client-grid,.shelf,.blog-grid,.cs-grid,.fields-2{ grid-template-columns:1fr; }
  .portrait-cap{ left:10px; }
  .scroll-hint{ display:none; }
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{ animation-duration:.01ms !important; animation-iteration-count:1 !important; transition-duration:.01ms !important; }
  html{ scroll-behavior:auto; }
  .rv{ opacity:1; transform:none; }
  #glyphs{ display:none; }
}

/* ============================================================
   AGATA FATEK — rozszerzenia "tech" (konstelacja, decode,
   spotlight, timeline, GRAI band, LinkedIn posts)
   ============================================================ */

/* portret kwadratowy */
.portrait.sq{ max-width:380px; }
.portrait.sq .portrait-frame{ aspect-ratio:1/1; }
.portrait.sq .portrait-frame img{ width:100%; height:100%; object-fit:cover; }

/* decode effect — znaki w trakcie scramble */
.roles .scr{ opacity:.55; }

/* GRAI band */
.grai{
  border-block:1px solid var(--line);
  background:
    radial-gradient(620px 240px at 14% 50%,rgba(201,162,39,.12),transparent 70%),
    linear-gradient(180deg,rgba(201,162,39,.06),rgba(201,162,39,.02));
  padding:54px 0;
}
.grai-inner{
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:34px;
  align-items:center;
}
.grai-seal{
  width:86px;height:86px;flex:none;
  border:1px solid var(--gold);
  border-radius:50%;
  display:grid;place-items:center;
  font-family:'Fraunces',serif;font-style:italic;font-weight:600;
  font-size:1.15rem;color:var(--gold-2);
  position:relative;
  background:radial-gradient(circle at 32% 28%,rgba(201,162,39,.25),transparent 70%);
}
.grai-seal::after{
  content:'';
  position:absolute; inset:-7px;
  border:1px dashed rgba(201,162,39,.4);
  border-radius:50%;
  animation:spin 26s linear infinite;
}
@keyframes spin{ to{ transform:rotate(360deg); } }
.grai h3{ font-size:clamp(1.2rem,2.4vw,1.7rem); margin-bottom:8px; }
.grai p{ color:var(--mist); font-size:.95rem; max-width:62ch; }

/* spotlight cards */
.spot{ position:relative; overflow:hidden; }
.spot::after{
  content:'';
  position:absolute; inset:0;
  background:radial-gradient(260px circle at var(--mx,50%) var(--my,50%),rgba(201,162,39,.1),transparent 65%);
  opacity:0;
  transition:opacity .4s;
  pointer-events:none;
}
.spot:hover::after{ opacity:1; }

/* timeline */
.timeline{
  position:relative;
  margin-top:56px;
  display:grid;
  gap:0;
}
.timeline::before{
  content:'';
  position:absolute; left:7px; top:8px; bottom:8px;
  width:1px;
  background:linear-gradient(180deg,var(--gold),rgba(201,162,39,.12));
}
.t-item{
  position:relative;
  padding:0 0 38px 44px;
}
.t-item::before{
  content:'';
  position:absolute; left:0; top:7px;
  width:15px;height:15px;border-radius:50%;
  border:1px solid var(--gold);
  background:var(--ink);
  box-shadow:0 0 0 4px var(--ink);
}
.t-item.now::before{
  background:var(--gold);
  box-shadow:0 0 0 4px var(--ink),0 0 18px rgba(201,162,39,.65);
}
.t-item time{
  font-family:'JetBrains Mono',monospace;
  font-size:.7rem; letter-spacing:.2em; color:var(--gold);
  text-transform:uppercase;
}
.t-item h3{ font-size:1.16rem; margin:8px 0 6px; }
.t-item p{ color:var(--mist); font-size:.93rem; max-width:72ch; }

/* quote */
.bigquote{
  border-left:3px solid var(--gold);
  background:linear-gradient(90deg,rgba(201,162,39,.07),transparent 70%);
  border-radius:0 var(--radius) var(--radius) 0;
  padding:28px 32px;
  margin:34px 0;
  font-family:'Fraunces',serif;
  font-style:italic;
  font-size:clamp(1.15rem,2.2vw,1.45rem);
  line-height:1.5;
  color:var(--paper);
}
.bigquote small{
  display:block; margin-top:14px;
  font-family:'JetBrains Mono',monospace; font-style:normal;
  font-size:.68rem; letter-spacing:.22em; text-transform:uppercase;
  color:var(--gold);
}

/* LinkedIn posts */
.li-cta{
  display:flex; align-items:center; gap:14px; flex-wrap:wrap;
}
.li-badge{
  display:inline-flex; align-items:center; gap:10px;
  border:1px solid var(--line);
  background:rgba(201,162,39,.06);
  border-radius:999px;
  padding:9px 18px;
  font-size:.82rem; font-weight:700; color:var(--gold-2);
}
.li-badge .pulse{
  width:8px;height:8px;border-radius:50%;
  background:var(--gold);
  animation:pulse 2s ease-out infinite;
}
@keyframes pulse{
  0%{ box-shadow:0 0 0 0 rgba(201,162,39,.55); }
  100%{ box-shadow:0 0 0 12px rgba(201,162,39,0); }
}
.post .src{
  font-family:'JetBrains Mono',monospace;
  font-size:.64rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--mist-2);
}

/* awards */
.awards{ display:grid; grid-template-columns:repeat(2,1fr); gap:18px; margin-top:50px; }
.award{
  display:flex; gap:18px; align-items:flex-start;
  border:1px solid var(--line-soft);
  border-radius:var(--radius);
  background:var(--ink-2);
  padding:24px 26px;
  transition:border-color .35s,transform .35s var(--ease);
}
.award:hover{ border-color:var(--line); transform:translateY(-4px); }
.award .laur{
  font-family:'Fraunces',serif; font-style:italic;
  color:var(--gold); font-size:1.5rem; flex:none;
}
.award h3{ font-size:1rem; margin-bottom:4px; }
.award p{ color:var(--mist); font-size:.86rem; }

/* cert chips grid */
.certs{ display:flex; flex-wrap:wrap; gap:10px; margin-top:30px; }
.certs .chip{ font-size:.74rem; padding:9px 16px; }
.certs .chip:hover{ border-color:var(--gold); color:var(--gold-2); }

@media (max-width:1020px){
  .grai-inner{ grid-template-columns:auto 1fr; }
  .grai-inner .btn{ grid-column:1/-1; justify-self:start; }
}
@media (max-width:760px){
  .awards{ grid-template-columns:1fr; }
  .grai-inner{ grid-template-columns:1fr; text-align:left; }
}

/* FIX: canvas konstelacji musi być warstwą tła hero (jak #glyphs) */
#neural{ position:absolute; inset:0; z-index:-2; }

/* FIX: stała wysokość dekodowanych ról — koniec skakania layoutu.
   Rola renderuje się w zarezerwowanym pudełku (2 linie zapasu),
   więc zmiana długości tekstu nie rusza niczego pod spodem. */
#roles{
  display:block;
  font-size:.52em;
  line-height:1.32;
  min-height:2.7em;
  margin-top:.4em;
  overflow-anchor:none;
}
