/* user.css – styl inspirowany układem climate.us
   Joomla / Cassiopeia
   Wgraj jako: media/templates/site/cassiopeia/css/user.css
*/

:root {
  --site-bg: #f6f1e8;
  --site-paper: #fffaf1;
  --site-text: #14212b;
  --site-muted: #5c6873;
  --site-line: rgba(20, 33, 43, 0.16);
  --site-blue: #183b63;
  --site-blue-dark: #102b49;
  --site-accent: #d96a3b;
  --site-radius: 18px;
  --site-shadow: 0 14px 36px rgba(20, 33, 43, 0.10);
  --site-max: 1180px;
}

html {
  scroll-behavior: smooth;
}

body.site {
  margin: 0;
  background: var(--site-bg);
  color: var(--site-text);
  font-family: Inter, "Source Sans 3", "Segoe UI", Roboto, Arial, sans-serif;
  font-size: 18px;
  line-height: 1.65;
}

body.site a {
  color: var(--site-blue);
  text-decoration-thickness: 1px;
  text-underline-offset: 4px;
}

body.site a:hover {
  color: var(--site-accent);
}

.site-grid,
.grid-child,
.container-component,
.container-sidebar-left,
.container-sidebar-right,
.container-topbar,
.container-header .grid-child,
.container-footer .grid-child {
  max-width: var(--site-max);
  margin-left: auto;
  margin-right: auto;
}

/* HEADER + MENU */
.container-header {
  background: var(--site-bg);
  background-image: none;
  box-shadow: none;
  border-bottom: 1px solid var(--site-line);
  position: sticky;
  top: 0;
  z-index: 1000;
}

.container-header .grid-child {
  padding: 18px 22px 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
}

.navbar-brand,
.container-header .navbar-brand {
  display: flex;
  align-items: center;
  gap: 14px;
  color: var(--site-text);
  font-weight: 800;
  letter-spacing: -0.03em;
  font-size: clamp(1.7rem, 3vw, 2.6rem);
  line-height: 1;
  text-decoration: none;
}

.container-header .site-description,
.container-header .tag-line,
.container-header p {
  margin: 4px 0 0;
  color: var(--site-muted);
  font-size: 0.95rem;
  font-weight: 500;
  letter-spacing: 0.01em;
}

.container-header .mod-menu,
.container-header .navbar-nav {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 6px 10px;
  margin: 0;
}

.container-header .mod-menu > li,
.container-header .navbar-nav > li {
  margin: 0;
}

.container-header .mod-menu a,
.container-header .navbar-nav .nav-link {
  color: var(--site-text);
  font-size: 0.95rem;
  font-weight: 700;
  padding: 9px 12px;
  border-radius: 999px;
  text-decoration: none;
}

.container-header .mod-menu a:hover,
.container-header .navbar-nav .nav-link:hover,
.container-header .mod-menu .active > a,
.container-header .navbar-nav .active > .nav-link {
  color: #fff;
  background: var(--site-blue);
}

/* HERO / BANER */
.container-banner,
.hero,
.moduletable.hero {
  max-width: var(--site-max);
  margin: 28px auto 36px;
  padding: 0 22px;
}

.container-banner .banneritem,
.hero .custom,
.moduletable.hero .custom {
  background: var(--site-blue-dark);
  color: #fff;
  border-radius: 26px;
  padding: clamp(34px, 7vw, 82px);
  box-shadow: var(--site-shadow);
}

.container-banner h1,
.hero h1,
.blog-featured > h1,
.com-content-article h1,
.page-header h1 {
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(2.4rem, 6vw, 5rem);
  line-height: 0.98;
  letter-spacing: -0.055em;
  margin: 0 0 20px;
  color: inherit;
}

.container-banner p,
.hero p {
  max-width: 760px;
  color: rgba(255, 255, 255, 0.88);
  font-size: clamp(1.1rem, 2vw, 1.35rem);
  margin-bottom: 0;
}

.btn,
.button,
.readmore a,
a.readmore,
.mod-articlesnews__readmore a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  border-radius: 999px;
  background: var(--site-accent);
  color: #fff !important;
  padding: 11px 18px;
  font-weight: 800;
  text-decoration: none !important;
  line-height: 1.2;
}

.btn:hover,
.button:hover,
.readmore a:hover,
a.readmore:hover,
.mod-articlesnews__readmore a:hover {
  filter: brightness(0.94);
}

/* TREŚĆ */
.main-top,
.container-component,
.blog-featured,
.com-content-category-blog,
.com-content-article {
  padding-left: 22px;
  padding-right: 22px;
}

.com-content-article,
.blog-featured,
.com-content-category-blog {
  max-width: var(--site-max);
  margin: 0 auto;
}

.com-content-article h2,
.blog-featured h2,
.com-content-category-blog h2,
.module h2,
.card-header {
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.9rem, 3.4vw, 3.2rem);
  line-height: 1.05;
  letter-spacing: -0.04em;
  color: var(--site-text);
  margin: 48px 0 18px;
}

.com-content-article h3,
.blog-featured h3,
.com-content-category-blog h3,
.module h3 {
  font-size: clamp(1.25rem, 2.1vw, 1.7rem);
  line-height: 1.15;
  letter-spacing: -0.025em;
  margin: 24px 0 10px;
  color: var(--site-blue-dark);
}

/* KARTY ARTYKUŁÓW / AKTUALNOŚCI */
.blog-items,
.items-leading,
.items-row,
.mod-articlesnews,
.newsflash,
.category-module,
.latestnews {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
}

.blog-item,
.items-leading > div,
.items-row > div,
.mod-articlesnews__item,
.newsflash-item,
.category-module li,
.latestnews li,
.card {
  background: var(--site-paper);
  border: 1px solid var(--site-line);
  border-radius: var(--site-radius);
  box-shadow: var(--site-shadow);
  overflow: hidden;
  padding: 0;
}

.blog-item .item-content,
.mod-articlesnews__item,
.newsflash-item,
.category-module li,
.latestnews li,
.card-body {
  padding: 20px;
}

.blog-item h2,
.blog-item h3,
.mod-articlesnews__item h3,
.newsflash h3,
.category-module h3,
.latestnews h3 {
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1.55rem;
  line-height: 1.12;
  letter-spacing: -0.035em;
  margin: 0 0 10px;
}

.article-info,
.published,
.createdby,
.category-name,
.mod-articles-category-date,
small {
  color: var(--site-muted);
  font-size: 0.88rem;
  font-weight: 650;
  letter-spacing: 0.02em;
}

/* OBRAZY */
img {
  max-width: 100%;
  height: auto;
}

.item-image,
.float-start.item-image,
.float-end.item-image {
  float: none !important;
  margin: 0 0 18px !important;
}

.item-image img,
.blog-item img,
.mod-articlesnews img,
.newsflash img,
.card img,
.com-content-article img {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  border-radius: 0;
}

.com-content-article img {
  border-radius: var(--site-radius);
  box-shadow: var(--site-shadow);
  margin: 24px 0;
}

/* BLOKI OBRAZ + TEKST */
.image-left,
.image-right,
.feature-row {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 34px;
  align-items: center;
  margin: 46px 0;
}

.image-right {
  grid-template-columns: 1.1fr 1fr;
}

.image-left img,
.image-right img,
.feature-row img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border-radius: var(--site-radius);
}

/* STOPKA */
.container-footer {
  background: var(--site-blue-dark);
  color: rgba(255, 255, 255, 0.86);
  margin-top: 70px;
  padding: 42px 22px;
}

.container-footer a {
  color: #fff;
}

.container-footer h2,
.container-footer h3 {
  color: #fff;
  margin-top: 0;
}

/* RESPONSYWNOŚĆ */
@media (max-width: 960px) {
  .container-header .grid-child {
    align-items: flex-start;
    flex-direction: column;
  }

  .container-header .mod-menu,
  .container-header .navbar-nav {
    justify-content: flex-start;
  }

  .blog-items,
  .items-leading,
  .items-row,
  .mod-articlesnews,
  .newsflash,
  .category-module,
  .latestnews {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 680px) {
  body.site {
    font-size: 16px;
  }

  .blog-items,
  .items-leading,
  .items-row,
  .mod-articlesnews,
  .newsflash,
  .category-module,
  .latestnews,
  .image-left,
  .image-right,
  .feature-row {
    grid-template-columns: 1fr;
  }

  .container-banner,
  .hero,
  .moduletable.hero,
  .main-top,
  .container-component,
  .blog-featured,
  .com-content-category-blog,
  .com-content-article {
    padding-left: 16px;
    padding-right: 16px;
  }

  .container-banner .banneritem,
  .hero .custom,
  .moduletable.hero .custom {
    border-radius: 20px;
    padding: 34px 24px;
  }
}
