/*!
Theme Name:   Anka Jot — Portfolio
Theme URI:    https://www.ankajot.pl
Author:       Anka Jędrzejak
Author URI:   https://www.ankajot.pl
Description:  Portfolio z pełną obsługą WCAG AA oraz wsparciem tłumaczeń wtyczki Polylang.
Template:     zooey
Version:      1.0.2
Requires PHP: 8.0
Tested up to: 6.7
Text Domain:  ankajot
License:      GPL-3.0-or-later
License URI:  https://www.gnu.org/licenses/gpl-3.0-standalone.html
*/

/* Skip links — a11y fix */
.skip-link.screen-reader-text {
  clip: rect(1px, 1px, 1px, 1px);
  position: absolute;
  left: -9999px;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

.skip-link.screen-reader-text:focus {
  clip: auto;
  left: 6px;
  top: 6px;
  width: auto;
  height: auto;
  overflow: visible;
  z-index: 9999;
  padding: 0.5rem 1rem;
  background: var(--color-base, #fff);
  color: var(--color-primary, #354BDB);
  border: 2px solid var(--color-primary, #354BDB);
  border-radius: 4px;
  font-weight: 600;
  text-decoration: none;
}

/* ---- General Sans — lokalny hosting ----------------------- */
@font-face {
  font-family: "General Sans";
  src: url("assets/fonts/GeneralSans-Light.woff") format("woff");
  font-weight: 300; font-style: normal; font-display: swap;
}
@font-face {
  font-family: "General Sans";
  src: url("assets/fonts/GeneralSans-Regular.woff") format("woff");
  font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
  font-family: "General Sans";
  src: url("assets/fonts/GeneralSans-Italic.woff") format("woff");
  font-weight: 400; font-style: italic; font-display: swap;
}
@font-face {
  font-family: "General Sans";
  src: url("assets/fonts/GeneralSans-Medium.woff") format("woff");
  font-weight: 500; font-style: normal; font-display: swap;
}
@font-face {
  font-family: "General Sans";
  src: url("assets/fonts/GeneralSans-Semibold.woff") format("woff");
  font-weight: 600; font-style: normal; font-display: swap;
}
@font-face {
  font-family: "General Sans";
  src: url("assets/fonts/GeneralSans-Bold.woff") format("woff");
  font-weight: 700; font-style: normal; font-display: swap;
}
/* ---- Design tokens: LIGHT (default) ----------------------- */
:root {
  --color-base:           #FEFEFE;
  --color-base-alt:       #F8F8F8;
  --color-contrast:       #141414;
  --color-body:           rgba(20, 20, 20, 0.80);
  --color-primary:        #354BDB;
  --color-primary-muted:  rgba(53, 75, 219, 0.10);
  --color-secondary:      #0E1E88;
  --color-muted:          rgba(20, 20, 20, 0.75);
  --color-border:         rgba(20, 20, 20, 0.10);
  --color-white:          #FFFFFF;

  /* Nav */
  --nav-bg:               rgba(254, 254, 254, 0.88);
  --nav-border:           rgba(20, 20, 20, 0.07);

  /* Typografia */
  --font-base:            "General Sans", sans-serif;

  /* Layout */
  --max-wide:             1280px;
  --gutter:               clamp(1.5rem, 5vw, 3rem);
  --nav-h:                60px;

  /* Animacje */
  --ease:                 cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --ease-out:             cubic-bezier(0.0, 0.0, 0.2, 1);
  --dur:                  0.65s;
}


/* ---- Design tokens: DARK ---------------------------------- */
html[data-theme="dark"] {
  --color-base:           #141414;
  --color-base-alt:       #1C1C1C;
  --color-contrast:       rgba(237, 237, 237, 0.90);
  --color-body:           rgba(237, 237, 237, 0.90);
  --color-primary:        #354BDB;
  --color-primary-alt:    #5168FE;
  --color-primary-muted:  rgba(53, 75, 219, 0.20);
  --color-secondary:      #354BDB;
  --color-muted:          rgba(237, 237, 237, 0.30);
  --color-border:         rgba(255, 255, 255, 0.10);
  --color-white:          #141414;

  --nav-bg:               rgba(20, 20, 20, 0.90);
  --nav-border:           rgba(255, 255, 255, 0.18);
}


/* ---- Reset ------------------------------------------------- */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

/* ---- Reduced motion + screen reader fallback -------------- */
@media (prefers-reduced-motion: reduce) {
  .scroll-reveal {
    opacity: 1;
    transform: none;
    transition: none;
  }
}
.wp-block-video
  {position: relative;
  overflow: hidden;
  aspect-ratio: 1600 / 1200;
  border-radius: var(--wp--custom--border-radius--image);
  background-color: #f0f0f0;
  }
.wp-block-video video
  {position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: contain !important;
  }
/* ---- Lightbox -------------------------------------------- */
.wp-lightbox-overlay .scrim
  {background-color: var(--color-base) !important;
  opacity: .5 !important;
  }
.wp-lightbox-overlay .close-button
  {fill: var(--color-body) !important;
  }

/* ---- Focus states (WCAG 2.4.7 AA) — nadpisuje Zooey ---------- */
:focus:not(:focus-visible),
*:focus:not(:focus-visible) {
  outline: none !important;
  box-shadow: none !important;
}

:focus-visible,
*:focus-visible {
  outline: 2px dashed var(--color-primary) !important;
  outline-offset: 4px !important;
  border-radius: 4px !important;
  box-shadow: none !important;
}

html {
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  transition: font-size 0.2s var(--ease);
  scroll-behavior: auto !important; /* wyłącz CSS smooth scroll — Lenis obsługuje scroll samodzielnie */
}

/* Zooey ustawia text-transform: lowercase na nagłówkach — resetujemy */
h1, h2, h3, h4, h5, h6 {
  text-transform: none;
  color: var(--color-contrast);
}

/* ---- Font scale -------------------------------------------- */
html[data-font="small"] { font-size: 14px; }
html[data-font="large"]  { font-size: 18px; }

.has-xl-font-size {text-transform: none !important;}

/* ---- Wysoki kontrast: light + HC --------------------------- */
[data-contrast="high"] {
  --color-base:           #FFD700;
  --color-base-alt:       #FFD700;
  --color-contrast:       #000000;
  --color-body:           #000000;
  --color-primary:        #000000;
  --color-primary-alt:    #000000;
  --color-primary-muted:  rgba(0, 0, 0, 0.15);
  --color-secondary:      #000000;
  --color-muted:          #000000;
  --color-white:          #FFD700;
  --nav-bg:               rgba(255, 215, 0, 0.97);
  --nav-border:           transparent;
}

/* ---- Wysoki kontrast: dark + HC ---------------------------- */
html[data-theme="dark"][data-contrast="high"] {
  --color-base:           #000000;
  --color-base-alt:       #000000;
  --color-contrast:       #FFD700;
  --color-body:           #FFD700;
  --color-primary:        #FFD700;
  --color-primary-alt:    #FFD700;
  --color-primary-muted:  rgba(255, 215, 0, 0.15);
  --color-secondary:      #FFD700;
  --color-muted:          #FFD700;
  --color-white:          #000000;
  --nav-bg:               rgba(0, 0, 0, 0.97);
  --nav-border:           transparent;
}

body {
  font-family: var(--font-base);
  font-size: clamp(1rem, 1.1vw, 1.125rem);
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: -0.08px;
  color: var(--color-body);
  background-color: var(--color-base);
  transition: background-color 0.4s var(--ease), color 0.4s var(--ease);
  overflow-x: hidden;
  padding-top: var(--nav-h); /* offset dla fixed nav */
}

@media (max-width: 768px) {
  body { padding-top: 72px; }
}

a { color: inherit; text-decoration: none !important; }
ul { list-style: none; }

strong {
  font-weight: 500;
}


/* ---- A11Y CONTROLS ----------------------------------------- */
.a11y-controls {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  flex-shrink: 0;
}

.a11y-font {
  display: flex;
  align-items: baseline;
  gap: 0.1rem;
}

.a11y-btn {
  background: transparent;
  border: none;
  cursor: pointer;
  color: var(--color-body);
  font-family: var(--font-base);
  font-weight: 500;
  line-height: 1;
  min-width: 24px;
  min-height: 24px;
  padding: 0.25rem 0.3rem;
  transition: color 0.2s var(--ease);
  border-radius: 4px;
}

/* Rozmiary A- / A / A+ */
#fontSmall  { font-size: 0.7rem; }
#fontNormal { font-size: 0.875rem; }
#fontLarge  { font-size: 1.1rem; }
.a11y-btn--lg { }

/* HC button — kółko jak theme-toggle */
.a11y-btn--hc {
  width: 34px;
  height: 34px;
  border: 1px solid var(--nav-border);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  margin-left: 0.25rem;
  transition:
    background 0.25s var(--ease),
    border-color 0.25s var(--ease),
    color 0.25s var(--ease);
}

.a11y-btn--hc svg {
  width: 15px;
  height: 15px;
}

.a11y-btn--hc:hover {
  background: var(--color-primary-muted);
  border-color: var(--color-primary);
  color: var(--color-primary);
}

/* A- A A+ hover / active */
.a11y-btn:hover,
.a11y-btn:active { color: var(--color-primary-alt); }

/* A- A A+ aktywny */
.a11y-btn.is-active {
  color: var(--color-primary-alt);
}

/* HC aktywny — wypełnione kółko jak hover ale permanentne */
[data-contrast="high"] .a11y-btn--hc,
.a11y-btn--hc[aria-pressed="true"] {
  background: var(--color-primary-muted);
  border-color: var(--color-primary-alt);
  color: var(--color-primary-alt);
}

/* ---- NAV --------------------------------------------------- */
.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
  height: var(--nav-h);
  background: var(--nav-bg);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  transition: background 0.4s var(--ease);
}

.nav__inner {
  max-width: var(--max-wide);
  margin: 0 auto;
  padding: 0 var(--gutter);
  height: 100%;
  display: flex;
  align-items: center;
  gap: 1.5rem;
}

/* Logo */
.nav__logo {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  flex-shrink: 0;
}

.nav__avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 1px solid var(--nav-border);
  object-fit: cover;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.625rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  color: var(--color-muted);
  flex-shrink: 0;
  overflow: hidden;
  transition: background 0.4s var(--ease), border-color 0.4s var(--ease);
}


.nav__logo-name {
  font-size: 1rem;
  font-weight: 500;
  color: var(--color-contrast);
  white-space: nowrap;
  transition: color 0.4s var(--ease);
}

/* Links — własne klasy + klasy bloku wp:navigation */
.nav__links,
.nav .wp-block-navigation {
  display: flex;
  align-items: center;
  gap: 0.125rem;
}

/* Nadpisuje reset marginesu z .is-layout-flex > :is(*,div) { margin: 0 } */
.nav .is-layout-flex > .nav__links,
.nav .is-layout-flex > .wp-block-navigation {
  margin-left: auto;
}

.nav .wp-block-navigation__container {
  display: flex;
  align-items: center;
  gap: 0.125rem;
  list-style: none;
  margin: 0;
  padding: 0;
}

.nav__link,
.nav .wp-block-navigation-item__content {
  position: relative;
  display: inline-block;
  padding: 0.35rem 0.7rem;
  font-size: 1rem;
  font-weight: 500;
  line-height: 1.4;
  color: var(--color-contrast);
  white-space: nowrap;
  transition: color 0.25s var(--ease);
}

/* Podkreślenie na hover */
.nav__link::after,
.nav .wp-block-navigation-item__content::after {
  content: "";
  position: absolute;
  bottom: 0.2rem;
  left: 0.7rem;
  right: 0.7rem;
  height: 1px;
  background: currentColor;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.3s var(--ease-out);
}

.nav__link:hover,
.nav .wp-block-navigation-item__content:hover { color: var(--color-primary); }

.nav__link:hover::after,
.nav .wp-block-navigation-item__content:hover::after { transform: scaleX(1); }

/* Aktywna strona */
.nav .current-menu-item .wp-block-navigation-item__content,
.nav .wp-block-navigation-item__content[aria-current="page"] {
  color: var(--color-primary);
}

.nav .current-menu-item::before,
.nav .current-menu-item::marker,
.nav .current-menu-item .wp-block-navigation-item__label::before {
  display: none !important;
  content: none !important;
}

.nav .current-menu-item .wp-block-navigation-item__content::after,
.nav .wp-block-navigation-item__content[aria-current="page"]::after {
  transform: scaleX(1);
}

/* Kontakt — filled pill button */
.nav__link--cta,
.nav .wp-block-navigation-item.nav__btn .wp-block-navigation-item__content {
  background: var(--color-primary);
  color: #FFFFFF !important;
  border-radius: 100px;
  padding: 0.4rem 1rem;
  font-weight: 500;
  transition: background 0.25s var(--ease);
}

[data-contrast="high"] .nav__link--cta,
[data-contrast="high"] .nav .wp-block-navigation-item.nav__btn .wp-block-navigation-item__content {
  color: var(--color-base) !important;
}

.nav__link--cta::after,
.nav .wp-block-navigation-item.nav__btn .wp-block-navigation-item__content::after { display: none; }

.nav__link--cta:hover,
.nav .wp-block-navigation-item.nav__btn .wp-block-navigation-item__content:hover {
  background: color-mix(in srgb, var(--color-primary) 70%, black);
}

/* EN / PL — z flagą */
.nav__link--lang, .wp-block-polylang-language-switcher, .nav__lang  {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.8125rem;
  font-weight: 500;
  margin-left: 0.25rem;
}

.lang-flag {
  width: 16px;
  height: 16px;
  border-radius: 50%!important;
  flex-shrink: 0;
  overflow: hidden;
  object-fit: cover;
  display: block;
}

.lang-flag .pl {
 background-image: url(https://link.ankajot.pl/pl.svg);
 }


/* ---- TOGGLE ----------------------------------------------- */
.theme-toggle {
  flex-shrink: 0;
  width: 34px;
  height: 34px;
  padding: 0;
  border: 1px solid var(--nav-border);
  border-radius: 50%;
  background: transparent;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-body);
  position: relative;
  transition:
    background 0.25s var(--ease),
    border-color 0.25s var(--ease),
    color 0.25s var(--ease),
    transform 0.2s var(--ease);
}

.theme-toggle:hover {
  background: var(--color-primary-muted);
  border-color: var(--color-primary);
  color: var(--color-primary);
}

.toggle-icon {
  width: 15px;
  height: 15px;
  position: absolute;
  transition: opacity 0.3s var(--ease), transform 0.3s var(--ease);
}

/* Light mode: księżyc widoczny */
.toggle-icon--moon { opacity: 1; transform: scale(1) rotate(0deg); }
.toggle-icon--sun  { opacity: 0; transform: scale(0.5) rotate(-90deg); }

/* Dark mode: słońce widoczne */
html[data-theme="dark"] .toggle-icon--moon { opacity: 0; transform: scale(0.5) rotate(90deg); }
html[data-theme="dark"] .toggle-icon--sun  { opacity: 1; transform: scale(1) rotate(0deg); }


/* ---- HERO -------------------------------------------------- */
/* Figma: height 600, padding-top 128, centered X+Y, gap 0 */
.hero {
  height: 600px;
  padding-top: 128px;
  display: flex;
  flex-direction: column;
  justify-content: center; /* cała grupa (tekst + strzałka) wyśrodkowana */
  align-items: center;
  gap: 0;
}

/* Figma: inner text container — bottom-padding 32, gap 8 */
.hero__inner {
  width: 100%;
  max-width: var(--max-wide);
  padding: 0 var(--gutter) 32px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

/* Figma: h1 — 50px desktop / 44px tablet / 30px mobile */
.hero__heading span {
  display: block;
  color: inherit !important;           /* nadpisuje inline color z bloku WP */
  background-color: transparent !important; /* nadpisuje inline background z bloku WP */
}
.hero__heading {
  font-size: 3.125rem; /* 50px */
  font-weight: 500;
  line-height: 1.4;
  color: var(--color-primary);
  transition: color 0.4s var(--ease);
}
html[data-theme="dark"] .hero__heading {
  color: var(--color-primary-alt);
}

@media (max-width: 768px) {
  .hero__heading {
    font-size: 2.75rem; /* 44px */
  }

  .hero {
    height: 360px;
    padding-top: 0;
    justify-content: center;
    align-items: center;
  }

  .hero__inner {
    justify-content: flex-end;
    align-items: center;
    padding: 0 8px;
    gap: 16px;
    height: 296px;
  }

  .hero__arrow {
    width: 56px;
    height: 64px;
    padding: 16px 16px 24px;
    justify-content: flex-start;
  }
}

@media (max-width: 400px) {
  .hero__heading {
    font-size: 1.875rem; /* 30px */
    text-align: center;
    letter-spacing: -0.005em;
  }

  .hero__heading span {
    display: inline;
  }

  .hero__sub {
    text-align: center;
  }
}

/* Figma: "i wszystko pomiędzy" — 18px medium, right-align */
.hero__sub {
  font-size: 1.125rem; /* 18px */
  font-weight: 500;
  line-height: 1.44;
  text-align: right;
  color: var(--color-contrast);
  transition: color 0.4s var(--ease);
}

/* Figma: arrow container — bottom-padding 24, ikona 24×24 */
.hero__arrow {
  width: 100%;
  display: flex;
  justify-content: center;
  padding-bottom: 24px;
  color: var(--color-muted);
  transition: color 0.3s var(--ease);
}

.hero__arrow svg {
  width: 24px;
  height: 24px;
  transition: transform 0.4s var(--ease);
}

.hero__arrow:hover { color: var(--color-primary); }
.hero__arrow:hover svg { transform: translateY(5px); }


/* ---- O MNIE ----------------------------------------------- */
/* Figma: padding top/bottom 96, gap kolumn 32, col-1: 270px, col-2/3: equal */
.about {
  background-color: var(--color-base);
  padding: 96px 0;
  transition: background-color 0.4s var(--ease);
}

.about__inner {
  max-width: var(--max-wide);
  margin: 0 auto;
  padding: 0 var(--gutter);
  display: grid;
  grid-template-columns: 270px 1fr 1fr;
  gap: 32px;
  align-items: start;
}

@media (max-width: 768px) {
  /* Nav mobile */
  .nav { height: 72px; }
  .nav__inner { padding: 0 16px; }
  .nav__avatar { width: 40px; height: 40px; }
  .nav__logo-name { display: block; }
  .a11y-controls { display: none; } /* przeniesione do overlay przez JS */
  .nav__lang { display: none; }

  /* About */
  .about { padding: 32px 0; }
  .about__inner { grid-template-columns: 1fr; gap: 1.5rem; }
}


/* ---- MOBILE OVERLAY MENU ---------------------------------- */

/* Hamburger — kolor z tokenu, reaguje na tryby */
.wp-block-navigation__responsive-container-open {
  background: none;
  border: 1px solid var(--nav-border);
  box-shadow: none;
  cursor: pointer;
  padding: 4px;
  color: var(--color-contrast);
}
.wp-block-navigation__responsive-container-open svg {
  fill: var(--color-contrast);
}

/* Overlay panel — dropdown pod navem, nie full-screen */
.wp-block-navigation__responsive-container.is-menu-open {
  position: fixed !important;
  top: var(--nav-h) !important;
  left: 0 !important;
  right: 0 !important;
  bottom: auto !important;
  width: 100% !important;
  height: auto !important;
  min-height: 0 !important;
  padding: 0 !important;                 /* reset Zooey: padding-inline: 6vw */
  background: none !important;           /* Zooey wymusza none — nie walczymy */
  z-index: 999;
}

/* Dialog = właściwy panel z treścią — tu dajemy blur + tło */
/* double .is-menu-open bije Zooey's specificity */
.wp-block-navigation__responsive-container.is-menu-open.is-menu-open
.wp-block-navigation__responsive-dialog {
  position: static !important;
  height: auto !important;
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  background: var(--nav-bg) !important;
  backdrop-filter: blur(16px) !important;
  -webkit-backdrop-filter: blur(16px) !important;
  border-bottom: 1px solid var(--nav-border);
  box-shadow: 0 8px 24px rgba(0,0,0,0.08);
}

.wp-block-navigation__responsive-container.is-menu-open
.wp-block-navigation__responsive-close {
  position: static !important;
  height: auto !important;
  display: block !important;
}

/* Wewnętrzny div overlaya (solid bg Zooey) — resetujemy */
.wp-block-navigation__responsive-container.is-menu-open
.wp-block-navigation__responsive-overlay,
.wp-block-navigation__responsive-container.is-menu-open
.wp-block-navigation__responsive-overlay div {
  background: transparent !important;
  opacity: 1 !important;
  backdrop-filter: none !important;
}

/* Treść overlaya — linki + a11y */
.wp-block-navigation__responsive-container-content {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 24px !important;
  padding: 32px 24px !important;
}

/* Linki — kolor z tokenu, reagują na dark/HC automatycznie */
.wp-block-navigation__responsive-container.is-menu-open
.wp-block-navigation-item__content {
  color: var(--color-contrast) !important;
  font-size: 1.25rem !important;
  font-weight: 500 !important;
  text-decoration: none !important;
  background: none !important;
  border: none !important;
  padding: 0 !important;
}

/* Przycisk Kontakt w overlay */
.wp-block-navigation__responsive-container.is-menu-open
.nav__btn .wp-block-navigation-item__content {
  background: var(--color-primary) !important;
  color: #FFFFFF !important;
  padding: 10px 24px !important;
  border-radius: var(--radius-pill, 999px) !important;
}

/* Kontakt overlay — HC override (light HC: żółty, dark HC: czarny) */
[data-contrast="high"]
.wp-block-navigation__responsive-container.is-menu-open
.nav__btn .wp-block-navigation-item__content {
  color: var(--color-base) !important;
}

/* X — zamknij, tylko gdy overlay otwarty */
.wp-block-navigation__responsive-container.is-menu-open
.wp-block-navigation__responsive-container-close {
  display: flex !important;
  position: absolute !important;
  top: 16px !important;
  right: 16px !important;
  background: none !important;
  border: 1px solid var(--nav-border) !important;
  box-shadow: none !important;
  cursor: pointer !important;
  padding: 4px !important;
  color: var(--color-contrast) !important;
}
.wp-block-navigation__responsive-container.is-menu-open
.wp-block-navigation__responsive-container-close svg {
  fill: var(--color-contrast) !important;
  width: 20px !important;
  height: 20px !important;
}

/* Overlay tło — transparentne, klik poza zamyka */
.wp-block-navigation__responsive-overlay {
  display: block !important;
  background: transparent !important;
  position: fixed !important;
  inset: 0 !important;
  z-index: -1 !important;
}

/* a11y-controls wewnątrz overlaya */
.wp-block-navigation__responsive-container-content .a11y-controls {
  display: flex !important;
  margin-top: 8px;
}

/* Podkreślenie aktywnego linku — wyrównaj do tekstu (reset desktop offset) */
.wp-block-navigation__responsive-container-content
.wp-block-navigation-item__content::after {
  left: 0 !important;
  right: 0 !important;
}





.about__label {
  font-size: 1.125rem; /* 18px */
  font-weight: 500;
  line-height: 1.4;
  color: var(--color-contrast);
  transition: color 0.4s var(--ease);
}

.about__col p {
  font-size: 1rem; /* 16px */
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: -0.005em;
  color: var(--color-body);
}

.about__col p + p { margin-top: 1rem; }


/* ---- ANIMACJE: PAGE LOAD ---------------------------------- */
.load-reveal {
  opacity: 0;
  transform: translateY(18px);
}

.load-reveal.is-loaded {
  opacity: 1;
  transform: translateY(0);
}

.load-reveal--1.is-loaded { transition: opacity 0.8s var(--ease), transform 0.8s var(--ease); transition-delay: 0.1s; }
.load-reveal--2.is-loaded { transition: opacity 0.7s var(--ease), transform 0.7s var(--ease); transition-delay: 0.35s; }
.load-reveal--3.is-loaded { transition: opacity 0.6s var(--ease), transform 0.6s var(--ease); transition-delay: 0.55s; }


/* ---- ANIMACJE: SCROLL REVEAL ------------------------------ */
.scroll-reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease);
}

.scroll-reveal.is-visible { opacity: 1; transform: translateY(0); }
.scroll-reveal--delay-1.is-visible { transition-delay: 0.1s; }
.scroll-reveal--delay-2.is-visible { transition-delay: 0.2s; }


/* ---- PROJEKTY --------------------------------------------- */
.projects {
  background-color: var(--color-base-alt);
  padding: 96px 0;
  transition: background-color 0.4s var(--ease);
}

.projects__inner {
  max-width: var(--max-wide);
  margin: 0 auto;
  padding: 0 var(--gutter);
  display: flex;
  flex-direction: column;
  gap: 64px;
}

.projects__heading {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  gap: 80px;
  font-size: 3.125rem; /* 50px */
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: -0.005em;
}

.heading--neutral {
  color: var(--color-contrast);
  transition: color 0.4s var(--ease);
}

.heading--accent {
  color: var(--color-primary-alt);
  transition: color 0.4s var(--ease);
}

@media (max-width: 1024px) {
  .projects__heading { font-size: 2.5rem; gap: 40px; }
}

@media (max-width: 768px) {
  .projects__heading { font-size: 1.875rem; line-height: 1.2; gap: 8px; }
}

/* Project card — info left, carousel right */
.project-card {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  gap: 142px;
}

@media (max-width: 1024px) {
  .project-card { gap: 40px; }
}

@media (max-width: 768px) {
  .project-card {
    flex-direction: column;
    gap: 16px;
  }
  .project-card__carousel { order: -1; }
}

/* Carousel */
.project-card__carousel {
  display: flex;
  flex-direction: column;
  gap: 20px;
  flex: 1;
  min-width: 0;
}

.carousel__window {
  overflow: hidden;
  border-radius: 12px;
  aspect-ratio: 788 / 466;
}

.carousel__track {
  display: flex;
  flex-direction: row;
  gap: 24px;
  height: 100%;
  transition: transform 0.5s var(--ease);
}

.carousel__slide {
  width: 100%;
  height: 100%;
  flex-shrink: 0;
  object-fit: cover;
  border-radius: 12px;
}

/* Progress bar */
.carousel__progress {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
}

.carousel__counter {
  font-size: 0.875rem; /* 14px */
  font-weight: 400;
  line-height: 1.4;
  color: rgba(20, 20, 20, 0.75);
  transition: color 0.4s var(--ease);
}

[data-theme="dark"] .carousel__counter {
  color: rgba(255, 255, 255, 0.5);
}

.carousel__nav {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 2px;
}

.carousel__nav-btn {
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: none;
  cursor: pointer;
  color: var(--color-contrast);
  opacity: 0.7;
  padding: 0;
  transition: color 0.2s var(--ease), opacity 0.2s var(--ease);
}

.carousel__nav-btn:hover { color: var(--color-primary); opacity: 1; }
.carousel__nav-btn:last-child { opacity: 1; }

/* Info */
.project-card__info {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 12px;
  padding-bottom: 20px;
  width: 270px;
  flex-shrink: 0;
}

.project-card__title {
  font-size: 1.5rem;
  font-weight: 500;
  line-height: 1.3;
  letter-spacing: -0.2px;
  color: var(--color-contrast);
  transition: color 0.4s var(--ease);
}

.project-card__desc {
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.5;
  color: var(--color-body);
  text-wrap: balance;
  transition: color 0.4s var(--ease);
}

.project-card__tags {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: flex-start;
  align-content: flex-start;
  gap: 8px;
  list-style: none;
  padding: 0;
  margin: 0;
}

.project-card__tags li {
  display: flex;
  align-items: center;
  font-size: 0.75rem; /* 12px */
  font-weight: 500;
  line-height: 20px;
  border-radius: 6px;
  padding: 1.5px 6px 2.5px;
}

.tag--ui        { background: rgba(239, 176, 126, 0.2); color: #F89E56; }
.tag--prototype { background: rgba(255, 163, 235, 0.2); color: #EF6BD2; }
.tag--landing   { background: rgba(192, 243, 113, 0.2); color: #8BB151; }
.tag--info      { background: rgba(11,  11,  11,  0.1); color: #0B0B0B; }
[data-theme="dark"] .tag--info { background: rgba(255, 255, 255, 0.1); color: rgba(255,255,255,0.75); }

/* HC: wszystkie tagi — ramka + tekst w --color-contrast, bez kolorów tła
   light HC: czarna ramka + czarny tekst (na żółtym tle)
   dark  HC: żółta ramka + żółty tekst (na czarnym tle) */
[data-contrast="high"] .tag--ui,
[data-contrast="high"] .tag--prototype,
[data-contrast="high"] .tag--landing,
[data-contrast="high"] .tag--info,
[data-contrast="high"] .tag--branding,
[data-contrast="high"] .tag--concept,
[data-contrast="high"] .tag--redesign,
[data-contrast="high"] .tag--book {
  background: transparent;
  color: var(--color-contrast);
  outline: 1px solid var(--color-contrast);
}
.tag--branding  { background: rgba(251, 224, 114, 0.2); color: #EFC51F; }
.tag--concept   { background: rgba(0,   213, 255, 0.2);  color: #00A4C4; }
.tag--redesign  { background: rgba(53,  75,  219, 0.2);  color: #354BDB; }
.tag--book      { background: rgba(251, 224, 114, 0.2);  color: #EFC51F; }

.project-card__link {
  display: inline-flex;
  flex-direction: row;
  align-items: center;
  padding: 6px 0;
  gap: 10px;
  height: 32px;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-contrast);
  text-decoration: none;
  margin-top: 8px;
  transition: opacity 0.2s var(--ease);
}

.project-card__link span {
  display: flex;
  align-items: center;
  padding-right: 8px;
  font-weight: 500;
  font-size: 0.875rem;
  line-height: 1.4;
  letter-spacing: 0.005em;
  color: var(--color-contrast);
}

.project-card__link svg {
  transition: transform 0.2s var(--ease), color 0.2s var(--ease);
}

.project-card__link:hover { opacity: 1; }
.project-card__link:hover span,
.project-card__link:hover svg { color: var(--color-primary); }
.project-card__link:hover svg { transform: rotate(-45deg); }


/* ---- WP BLOCK GAP — wycisz dla wszystkich sekcji głównych --- */
.wp-block-post-content > .wp-block-group.alignfull,
.projects,
.other,
.hero,
.skills,
.about,
.contact {
  margin-block: 0 !important;
}

.wp-block-post-content > .wp-block-group.alignfull {
  padding-block: 0 !important;
}

/* ============================================================
   CTA — blok z wezwaniem do działania
   ============================================================ */

.cta {
  padding: var(--gutter) 0;
}

.cta__card {
  max-width: var(--max-wide);
  min-height: 267px;
  margin: 0 auto;
  padding: 48px 64px;
  background: rgba(229, 233, 241, 0.5);
  border-radius: 8px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 20px;
  align-content: center;
  align-items: center;
  text-align: center;
}

html[data-theme="dark"] .cta__card {
  background: var(--color-base-alt);
}

.cta__heading {
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.2;
  color: var(--color-contrast);
  margin: 0;
}

.cta__text {
  font-size: 1rem;
  line-height: 1.6;
  color: var(--color-body);
  max-width: 560px;
  margin: 0;
}

.cta__btn {
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  padding: 7px 24px;
  width: 280px;
  height: 40px;
  background: var(--color-primary);
  color: #FFFFFF !important;
  border-radius: 200px;
  font-size: 0.9375rem;
  font-weight: 500;
  text-decoration: none !important;
  transition: background 0.2s var(--ease);
  flex-shrink: 0;
}
[data-contrast="high"] .cta__btn {
	color: var(--color-base) !important;
}
.cta__btn:hover {
  background: color-mix(in srgb, var(--color-primary) 70%, black);
}

@media (max-width: 480px) {
  .cta__btn { width: 210px; }
}

@media (max-width: 768px) {
  .cta__card {
    min-height: 267px;
    padding: 40px 32px;
  }
  .cta__heading { font-size: 1.5rem; }
}

@media (max-width: 480px) {
  .cta__card {
    min-height: 199px;
    padding: 32px 24px;
  }
  .cta__heading { font-size: 1.25rem; }
}

/* ============================================================
   CONTACT — Kontakt
   ============================================================ */

.contact {
  background-color: var(--color-base);
  padding: 96px 0;
  transition: background-color 0.4s var(--ease);
}

.contact__inner {
  max-width: var(--max-wide);
  margin: 0 auto;
  padding: 0 var(--gutter);
  display: flex;
  flex-direction: column;
  gap: 64px;
}

.contact__heading {
  font-size: 3.125rem;
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: -0.005em;
  color: var(--color-contrast);
  transition: color 0.4s var(--ease);
}

.contact__cols {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  gap: 40px;
}

.contact__col--info {
  flex: 0 0 320px;
  display: flex;
  flex-direction: column;
  gap: 30px;
}

.contact__col--form {
  flex: 1;
}

.contact__desc {
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.4;
  color: var(--color-body);
  transition: color 0.4s var(--ease);
}

.contact__email {
  font-size: 1.0625rem; /* 17px */
  font-weight: 500;
  line-height: 1.2;
  color: var(--color-contrast);
  text-decoration: none;
  transition: color 0.2s var(--ease);
}

.contact__email:hover { color: var(--color-primary); }

.contact__social { display: flex; flex-direction: column; gap: 4px; }

.contact__social-label {
  font-size: 0.875rem; /* 14px */
  font-weight: 500;
  line-height: 1.4;
  color: var(--color-contrast);
  transition: color 0.4s var(--ease);
}

.contact__social-links {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
}

.contact__social-link {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 8px;
  width: 100px;
  height: 32px;
  font-size: 0.875rem; /* 14px */
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: -0.005em;
  color: var(--color-body);
  text-decoration: none;
  transition: color 0.2s var(--ease);
}

.contact__social-link:hover { color: var(--color-primary); }

.contact__social-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  font-size: 0.75rem;
  font-weight: 700;
}

.contact__portfolio {
  display: inline-flex;
  flex-direction: row;
  align-items: center;
  padding: 6px 0;
  gap: 10px;
  width: 127px;
  height: 32px;
  font-size: 0.9375rem;
  font-weight: 500;
  color: var(--color-contrast);
  text-decoration: none;
  transition: color 0.2s var(--ease);
}

.contact__portfolio:hover { color: var(--color-primary); }
.contact__portfolio svg { transition: transform 0.2s var(--ease); }
.contact__portfolio:hover svg { transform: rotate(-45deg); }

@media (max-width: 1024px) {
  .contact__heading { font-size: 2.5rem; }
  .contact__col--info { flex: 0 0 280px; }
}

@media (max-width: 768px) {
  .contact { padding: 40px 0; }
  .contact__inner { gap: 24px; }
  .contact__heading { font-size: 1.875rem; line-height: 1.2; }
  .contact__cols { flex-direction: column; }
  .contact__col--info { flex: none; }
  .contact__col--form { width: 100%; }
  .contact__col--form .container { width: 100% !important; max-width: 100% !important; padding: 0; }
  .contact__col--form .m-6 { margin: 0; }
  .contact__social-links { flex-wrap: wrap; gap: 4px 8px; }
}


/* ============================================================
   FOOTER
   ============================================================ */

/* ============================================================
   SKILLS — Co mogę dla Ciebie zrobić
   ============================================================ */

.skills {
  background-color: var(--color-base);
  padding: 96px 0;
  transition: background-color 0.4s var(--ease);
}

.skills__inner {
  max-width: var(--max-wide);
  margin: 0 auto;
  padding: 0 var(--gutter);
  display: flex;
  flex-direction: column;
  gap: 64px;
}

.skills__heading {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  gap: 80px;
  font-size: 3.125rem;
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: -0.005em;
}

/* .heading--neutral / .heading--accent — zdefiniowane w sekcji Projects */

.skills__cols {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  gap: 40px;
}

.skills__col--bio {
  flex: 0 0 320px;
}

.skills__bio {
  font-size: 0.9375rem;
  line-height: 1.6;
  color: var(--color-contrast);
  transition: color 0.4s var(--ease);
}

.skills__col--list {
  flex: 1;
}

.skills__col-heading {
  font-size: 1rem;
  font-weight: 500;
  line-height: 1.4;
  color: var(--color-contrast);
  padding-bottom: 16px;
  border-bottom: 1px solid var(--color-border);
  margin-bottom: 0;
  transition: color 0.4s var(--ease), border-color 0.4s var(--ease);
}

.skills__list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.skills__list li {
  font-size: 0.9375rem;
  line-height: 1.4;
  color: var(--color-contrast);
  padding: 14px 0;
  border-bottom: 1px solid var(--color-border);
  transition: color 0.4s var(--ease), border-color 0.4s var(--ease);
}

@media (max-width: 1024px) {
  .skills__heading { font-size: 2.5rem; gap: 40px; }
}

@media (max-width: 768px) {
  .skills { padding: 40px 0; }
  .skills__inner { gap: 24px; }
  .skills__heading { font-size: 1.875rem; flex-direction: column; gap: 8px; line-height: 1.2; }
  .skills__cols { flex-direction: column; gap: 24px; }
  .skills__col--bio { flex: none; width: 100%; }
  .skills__col--list { flex: none; width: 100%; padding-top: 8px; }
}


/* ============================================================ */

.footer {
  padding: 24px 0 32px;
  transition: background-color 0.4s var(--ease);
}

.footer__inner {
  max-width: var(--max-wide);
  margin: 0 auto;
  padding: 0 var(--gutter);
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
}

.footer__copy {
  font-size: 0.875rem;
  color: var(--color-contrast);
}

.footer__top {
  display: flex;
  flex-direction: row;
  justify-content: flex-end;
  align-items: center;
  gap: 4px;
  padding: 4px 0;
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1.35;
  letter-spacing: 0.005em;
  color: rgba(20, 20, 20, 0.8);
  text-decoration: none;
  transition: color 0.2s var(--ease);
}

[data-theme="dark"] .footer__top {
  color: rgba(255, 255, 255, 0.8);
}

.footer__top:hover { color: var(--color-primary); opacity: 1; }



/* ============================================================
   INNE PROJEKTY
   ============================================================ */

.other {
  background-color: var(--color-base-alt);
  padding: 96px 0;
  transition: background-color 0.4s var(--ease);
}

.other__inner {
  max-width: var(--max-wide);
  margin: 0 auto;
  padding: 0 var(--gutter);
  display: flex;
  flex-direction: column;
}

.other__header {
  margin-bottom: 80px;
}

.other__heading {
  font-size: clamp(2.5rem, 5vw, 3.5rem);
  font-weight: 500;
  line-height: 1;
  color: var(--color-contrast);
}

/* Karta — wiersz: info + galeria */
.other-card {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  gap: 80px;
  padding-bottom: 48px;
  margin-bottom: 48px;
}

.other-card:last-child {
  margin-bottom: 0;
  padding-bottom: 0;
}

/* Lewa kolumna — tytuł, tagi, link */
.other-card__info {
  width: 328px;
  min-width: 280px;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.other-card__title {
  font-size: 1.125rem;
  font-weight: 500;
  line-height: 1.3;
  color: var(--color-contrast);
}

/* Prawa kolumna — galeria */
.other-card__gallery {
  flex: 1;
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 16px;
  padding: 16px 0 0 0;
  overflow-x: auto;
  scrollbar-width: none;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
}

.other-card__gallery::-webkit-scrollbar { display: none; }

.other-card__img {
  flex: 0 0 calc((100% - 32px) / 3);
  width: calc((100% - 32px) / 3);
  height: 192px;
  border-radius: 10px;
  background: var(--color-surface);
  object-fit: cover;
  display: block;
  scroll-snap-align: start;
}

/* Mobile */
@media (max-width: 768px) {
  .other-card {
    flex-direction: column;
    gap: 24px;
  }

  .other-card__gallery { order: -1; }

  .other-card__info {
    width: 100%;
  }

  .other-card__gallery {
    width: 100%;
  }

  .other-card__img {
    flex: 0 0 160px;
    width: 160px;
    height: 140px;
  }
}


/* ===== CONTACT FORM — WP (własny CSS, bez Tailwinda) ===== */

.contact__form {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.contact__field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.contact__label {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--color-body);
}

.contact__input {
  width: 100%;
  padding: 10px 12px;
  background: var(--color-base-alt);
  border: 1.5px solid var(--color-border);
  border-radius: 6px;
  font-size: 0.9375rem;
  color: var(--color-contrast);
  font-family: inherit;
  transition: border-color 0.2s;
  box-sizing: border-box;
}

.contact__input:focus,
.contact__input:focus-visible {
  outline: none !important;
  box-shadow: none !important;
  border-color: var(--color-primary);
}

.contact__input::placeholder {
  color: var(--color-body);
  opacity: 0.5;
}

.contact__input--textarea {
  resize: vertical;
  min-height: 120px;
}

.h-captcha {
  margin-top: 8px;
  margin-bottom: 16px;
}

.contact__submit {
  width: 100%;
  padding: 14px 16px;
  background: var(--color-primary);
  color: #fff;
  border: none;
  border-radius: 6px;
  font-size: 0.9375rem;
  font-weight: 500;
  font-family: inherit;
  cursor: pointer;
  transition: background 0.2s;
  letter-spacing: -0.01em;
}

.contact__submit:hover {
  background-color: var(--color-secondary);
}

.contact__submit:focus-visible {
  outline: 2px dashed var(--color-primary);
  outline-offset: 4px;
}

.contact__result {
  font-size: 0.875rem;
  text-align: center;
  color: var(--color-body);
  min-height: 1.5em;
}

/* HC — formularz */
[data-contrast="high"] .contact__input {
  border-color: var(--color-contrast);
  background: var(--color-base);
}

[data-contrast="high"] .contact__submit {
  background: var(--color-primary) !important;
  border: none;
  color: var(--color-base) !important;
}
