:root{--bg:#1c1c1c;--steel:#f0f0f0;--dim:#d4d4d4;--white:#fff;--sand:#c4a882;--sandb:rgba(196,168,130,.35);--ease:cubic-bezier(.16,1,.3,1)}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;background:#1c1c1c}
body{font-family:'Inter',system-ui,sans-serif;color:var(--steel);min-height:100vh;overflow-x:hidden;background:#1c1c1c;display:flex;flex-direction:column}
.bg-wrap{position:fixed;inset:0;z-index:0}
.bg-wrap img{width:100%;height:100%;object-fit:cover;filter:blur(1px) brightness(.35);transform:scale(1.08)}
.bg-overlay{position:fixed;inset:0;z-index:1;background:linear-gradient(135deg,rgba(28,28,28,.7),rgba(28,28,28,.45),rgba(28,28,28,.75))}
body::before{content:'';position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='400' height='400'%3E%3Cfilter id='c'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.4' numOctaves='6' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='400' height='400' filter='url(%23c)' opacity='0.06'/%3E%3C/svg%3E");pointer-events:none;z-index:1;opacity:.12;mix-blend-mode:overlay}
.center-logo{position:relative;z-index:10;display:flex;justify-content:center;padding:0 5vw 0}
.center-logo a{display:block;}
.center-logo img{height:320px;width:auto}
main{position:relative;z-index:10;max-width:1200px;margin:0 auto 0;padding:1rem 5vw 3rem;flex:1}
.hero{border:1px solid rgba(255,255,255,.08);border-radius:16px;background:rgba(15,15,15,.65);backdrop-filter:blur(8px);padding:1.6rem 1.8rem;margin-bottom:1.2rem;text-align:center}
.hero .sub{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--sand);margin-bottom:.7rem}
.hero h1{font-size:clamp(1.8rem,3.2vw,2.5rem);font-weight:300;line-height:1.24}
.hero p{margin-top:.85rem;color:var(--dim);line-height:1.75;max-width:820px;margin-left:auto;margin-right:auto}

/* ── Cards grid – realizacje-style ──────────────── */
.grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}
.card{position:relative;overflow:hidden;aspect-ratio:16/9;border-radius:14px;background:rgba(0,0,0,.45);border:1px solid rgba(255,255,255,.08);box-shadow:0 8px 32px rgba(0,0,0,.25);transition:all .45s var(--ease);display:block;text-decoration:none;color:inherit}
.card:hover{transform:translateY(-4px);border-color:var(--sandb);box-shadow:0 18px 50px rgba(0,0,0,.5),0 0 30px rgba(196,168,130,.12)}
.card img{width:100%;height:100%;object-fit:cover;object-position:50% 25%;transition:transform .8s var(--ease),filter .5s;display:block}
.card:hover img{transform:scale(1.08);filter:brightness(0.5)}
.card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(6,8,15,.92) 0%,rgba(6,8,15,.55) 45%,rgba(6,8,15,.12) 80%,transparent 100%);opacity:1;display:flex;flex-direction:column;justify-content:flex-end;padding:1.8rem 1.6rem 1.5rem;transition:opacity .45s}
.card-overlay h2{font-size:1.15rem;font-weight:400;color:var(--white);line-height:1.3;letter-spacing:-.005em}
.card-overlay p{margin-top:.45rem;color:var(--dim);font-size:.93rem;line-height:1.65;opacity:0;transform:translateY(8px);max-height:0;overflow:hidden;transition:opacity .3s var(--ease),transform .3s var(--ease),max-height .3s var(--ease)}
.card:hover .card-overlay{opacity:1}
.card:hover .card-overlay p,.card:focus-visible .card-overlay p{opacity:1;transform:translateY(0);max-height:8rem}

@media (max-width:980px){.grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (hover:none){.card-overlay p{opacity:1;transform:none;max-height:8rem}}
@media (max-width:640px){.center-logo a{}.center-logo img{height:240px}.grid{grid-template-columns:1fr}.chat{bottom:calc(1.1rem - 5px)}.chat a{padding:.65rem 1.15rem}}

/* ── Floating contact bar ──────────────────────── */
.chat{position:fixed;bottom:calc(2rem - 5px);left:50%;transform:translateX(-50%);z-index:100;cursor:pointer}
.chat a{position:relative;display:flex;align-items:center;justify-content:center;text-decoration:none;padding:.75rem 1.5rem;gap:.5rem}
.chat .background{position:absolute;inset:0;border-radius:14px;background:rgba(0,0,0,.45);border:1px solid rgba(255,255,255,.1);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);transition:all .3s var(--ease)}
.chat .chat-icon{position:relative;z-index:2;width:20px;height:20px;color:#d4d4d4;transition:color .25s ease;flex-shrink:0}
.chat .chat-text{position:relative;z-index:2;font-size:.85rem;letter-spacing:.08em;color:#d4d4d4;white-space:nowrap;transition:color .25s ease}
.chat:hover .background{background:rgba(255,255,255,.12);border-color:var(--sandb);transform:scale(1.05)}
.chat:hover .chat-text,.chat:hover .chat-icon{color:var(--sand)}

/* ── FOOTER ───────────────────────────────────────── */
footer {
  padding:.8rem 5vw;
  display:flex; align-items:center; justify-content:center;
  position:relative; z-index:2;}
footer a { color:#999; text-decoration:none; transition:color .3s;}
footer a:hover { color:#ccc;}
.ft-text { font-size:.72rem; letter-spacing:.06em; color:#999;}
.ft-cookie { position:absolute; right:1.5vw; display:inline-flex; align-items:center; cursor:pointer; opacity:.6;}
.ft-cookie:hover { opacity:1;}


/* ── DEV LINK LOADER OVERLAY ───────────────────────── */
#dev-loader-overlay {
  position:fixed; inset:0; z-index:99999;
  display:none;
  align-items:center; justify-content:center;
  background:rgba(6,8,15,0.92);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);}
#dev-loader-overlay.active { display:flex;}

#dev-loader-overlay .loader {
  position: absolute;
  top: 50%;
  margin-left: -50px;
  left: 50%;
  animation: speeder 0.4s linear infinite;}
#dev-loader-overlay .loader > span {
  height: 5px;
  width: 35px;
  background: #ff6b9d;
  position: absolute;
  top: -19px;
  left: 60px;
  border-radius: 2px 10px 1px 0;}
#dev-loader-overlay .base span {
  position: absolute;
  width: 0;
  height: 0;
  border-top: 6px solid transparent;
  border-right: 100px solid #ff6b9d;
  border-bottom: 6px solid transparent;}
#dev-loader-overlay .base span:before {
  content: "";
  height: 22px;
  width: 22px;
  border-radius: 50%;
  background: #c44dff;
  position: absolute;
  right: -110px;
  top: -16px;
  box-shadow: 0 0 15px rgba(196,77,255,0.6);}
#dev-loader-overlay .base span:after {
  content: "";
  position: absolute;
  width: 0;
  height: 0;
  border-top: 0 solid transparent;
  border-right: 55px solid #4d9eff;
  border-bottom: 16px solid transparent;
  top: -16px;
  right: -98px;}
#dev-loader-overlay .face {
  position: absolute;
  height: 12px;
  width: 20px;
  background: #c44dff;
  border-radius: 20px 20px 0 0;
  transform: rotate(-40deg);
  right: -125px;
  top: -15px;
  box-shadow: 0 0 10px rgba(196,77,255,0.4);}
#dev-loader-overlay .face:after {
  content: "";
  height: 12px;
  width: 12px;
  background: #4d9eff;
  right: 4px;
  top: 7px;
  position: absolute;
  transform: rotate(40deg);
  transform-origin: 50% 50%;
  border-radius: 0 0 0 2px;
  box-shadow: 0 0 8px rgba(77,158,255,0.4);}
#dev-loader-overlay .loader > span > span:nth-child(1) {
  width: 30px;
  height: 1px;
  background: #ff6b9d;
  position: absolute;
  animation: fazer1 0.2s linear infinite;}
#dev-loader-overlay .loader > span > span:nth-child(2) {
  width: 30px;
  height: 1px;
  background: #c44dff;
  position: absolute;
  top: 3px;
  animation: fazer2 0.4s linear infinite;}
#dev-loader-overlay .loader > span > span:nth-child(3) {
  width: 30px;
  height: 1px;
  background: #4d9eff;
  position: absolute;
  top: 1px;
  animation: fazer3 0.4s linear infinite;
  animation-delay: -1s;}
#dev-loader-overlay .loader > span > span:nth-child(4) {
  width: 30px;
  height: 1px;
  background: #ff6b9d;
  position: absolute;
  top: 4px;
  animation: fazer4 1s linear infinite;
  animation-delay: -1s;}
@keyframes fazer1 {
  0% { left: 0;}
  100% { left: -80px; opacity: 0;}}
@keyframes fazer2 {
  0% { left: 0;}
  100% { left: -100px; opacity: 0;}}
@keyframes fazer3 {
  0% { left: 0;}
  100% { left: -50px; opacity: 0;}}
@keyframes fazer4 {
  0% { left: 0;}
  100% { left: -150px; opacity: 0;}}
@keyframes speeder {
  0%   { transform: translate(2px, 1px) rotate(0deg);}
  10%  { transform: translate(-1px, -3px) rotate(-1deg);}
  20%  { transform: translate(-2px, 0px) rotate(1deg);}
  30%  { transform: translate(1px, 2px) rotate(0deg);}
  40%  { transform: translate(1px, -1px) rotate(1deg);}
  50%  { transform: translate(-1px, 3px) rotate(-1deg);}
  60%  { transform: translate(-1px, 1px) rotate(0deg);}
  70%  { transform: translate(3px, 1px) rotate(-1deg);}
  80%  { transform: translate(-2px, -1px) rotate(1deg);}
  90%  { transform: translate(2px, 1px) rotate(0deg);}
  100% { transform: translate(1px, -2px) rotate(-1deg);}}
#dev-loader-overlay .longfazers {
  position: absolute;
  width: 100%;
  height: 100%;}
#dev-loader-overlay .longfazers span {
  position: absolute;
  height: 2px;
  width: 20%;
  opacity: 0.5;}
#dev-loader-overlay .longfazers span:nth-child(1) {
  top: 20%;
  background: #ff6b9d;
  animation: lf 0.6s linear infinite;
  animation-delay: -5s;}
#dev-loader-overlay .longfazers span:nth-child(2) {
  top: 40%;
  background: #c44dff;
  animation: lf2 0.8s linear infinite;
  animation-delay: -1s;}
#dev-loader-overlay .longfazers span:nth-child(3) {
  top: 60%;
  background: #4d9eff;
  animation: lf3 0.6s linear infinite;}
#dev-loader-overlay .longfazers span:nth-child(4) {
  top: 80%;
  background: #ff6b9d;
  animation: lf4 0.5s linear infinite;
  animation-delay: -3s;}
@keyframes lf {
  0% { left: 200%;}
  100% { left: -200%; opacity: 0;}}
@keyframes lf2 {
  0% { left: 200%;}
  100% { left: -200%; opacity: 0;}}
@keyframes lf3 {
  0% { left: 200%;}
  100% { left: -100%; opacity: 0;}}
@keyframes lf4 {
  0% { left: 200%;}
  100% { left: -100%; opacity: 0;}}

.hero--compact{margin-bottom:1rem}.hero-heading{font-size:clamp(1.2rem,2.3vw,1.7rem);font-weight:400;line-height:1.3}
