/*
Theme Name: Pollyart Theme
Theme URI: https://pollyart.pl
Description: Custom theme for Pollyart Blog
Version: 2.0
Author: Pollyart
*/

/* ============================================
   FONTS - loaded from pollyart.pl
   ============================================ */
@font-face { font-family:'open_sanslight'; src:url('fonts/opensans-light.woff2') format('woff2'), url('fonts/opensans-light.woff') format('woff'); font-weight:normal; font-display:swap; }
@font-face { font-family:'open_sansregular'; src:url('fonts/opensans-regular.woff2') format('woff2'), url('fonts/opensans-regular.woff') format('woff'); font-weight:normal; font-display:swap; }
@font-face { font-family:'open_sanssemibold'; src:url('fonts/opensans-semibold.woff2') format('woff2'), url('fonts/opensans-semibold.woff') format('woff'); font-weight:normal; font-display:swap; }
@font-face { font-family:'playfair_displayregular'; src:url('fonts/playfairdisplay-regular.woff2') format('woff2'), url('fonts/playfairdisplay-regular.woff') format('woff'); font-weight:normal; font-display:swap; }
@font-face { font-family:'playfair_displaybold'; src:url('fonts/playfairdisplay-bold.woff2') format('woff2'), url('fonts/playfairdisplay-bold.woff') format('woff'); font-weight:700; font-display:swap; }

/* ============================================
   RESET & BASE
   ============================================ */
:root { --default-border-radius: 999px; }
*, *::before, *::after { box-sizing: border-box; }
html, body, div, span, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, nav, output, ruby, section, summary, time, mark, audio, video {
  margin:0; padding:0; border:0; font-size:100%; font:inherit; vertical-align:baseline;
}
html, body { height:100%; }
body { font-family:'open_sanslight'; color:#262626; background:#fff; -webkit-tap-highlight-color:rgba(0,0,0,0); }
strong { font-weight:700; }
em { font-style:italic; }
ol, ul { list-style:none; }
img { max-width:100%; }
a { outline:none; cursor:pointer; }
input, textarea { outline:none; font-family:'open_sanslight' !important; }
button, a, input[type='checkbox'], input[type='submit'], label { outline:none; cursor:pointer; font-family:'open_sansregular' !important; }

.page-container { overflow:hidden; background:#fff; }

/* ============================================
   CONTAINERS
   ============================================ */
.nav-container { max-width:1920px; margin:0 auto; padding-inline:max(70px, 5vw); width:100%; box-sizing:content-box; }
.main-container { max-width:1240px; margin:0 auto; width:100%; }
.small-container { max-width:845px; margin:0 auto; width:100%; }

/* ============================================
   NAVBAR
   ============================================ */
.main-navbar {
  position:absolute; top:0; left:0; z-index:999; width:100%;
  display:flex; justify-content:center;
  border-top:6px solid #fec013;
  padding:20px 0 20px;
  background-image:linear-gradient(rgba(0,0,0,0.7) 0%, rgba(0,0,0,0.21) 50%, rgba(0,0,0,0) 100%);
}
.main-navbar nav {
  width:100%; display:flex; justify-content:space-between; align-items:center;
}
.logo img { width:200px; }

/* Desktop menu */
.menu { display:flex; align-items:center; }
.menu .menu-container { display:flex; margin-right:20px; }
.menu .menu-link, .menu .menu-item {
  color:#fff; font-size:18px; margin:0 10px; text-decoration:none;
  text-transform:lowercase; font-weight:300; padding:10px 5px;
  position:relative; display:block; font-family:'open_sansregular'; user-select:none;
}
.menu .menu-link:after, .menu .menu-item:after {
  content:''; position:absolute; top:90%; left:0; display:block;
  background:#fec013; height:5px; width:0; border-radius:30px;
  transition:all 0.2s ease;
}
.menu .menu-link:hover:after, .menu .active .menu-link:after,
.menu .menu-item:hover:after, .menu .active .menu-item:after { width:100%; }

.menu .menu-action-btn {
  color:#fec013; border:none; background:#fff; font-size:20px;
  border-radius:var(--default-border-radius); padding:8px 30px;
  transition:all 0.2s ease; text-decoration:none;
}
.menu .menu-action-btn:hover { background:#fec013 !important; color:#fff !important; }

/* Submenus */
.menu-container > .has-children { position:relative; }
.menu-container > .has-children .sub-menu {
  position:absolute; top:100%; left:50%; transform:translateX(-50%);
  opacity:0; visibility:hidden; margin:0; background:#fec013; color:#f6f6f6;
  transition:200ms ease; flex-direction:column; z-index:1; display:flex;
}
.menu-container > .has-children .sub-menu .sub-menu {
  top:0; right:100%; left:unset; transform:translateX(0);
}
.menu-container > .has-children:hover > .sub-menu,
.menu-container > .has-children:active > .sub-menu { opacity:1; visibility:visible; }
.menu-container > .has-children .sub-menu .menu-link,
.menu-container > .has-children .sub-menu .menu-item {
  color:inherit; white-space:nowrap; padding-block:1em; padding-inline:2em; margin:0; transition:200ms ease;
}
.menu-container > .has-children .sub-menu .menu-link:hover,
.menu-container > .has-children .sub-menu .menu-item:hover { background:#f6f6f6; color:#232323; }
.menu-container > .has-children .sub-menu .menu-link:after,
.menu-container > .has-children .sub-menu .menu-item:after { content:none; }

/* ============================================
   MOBILE MENU
   ============================================ */
.mobile-menu {
  position:fixed; top:20px; right:10px; display:none;
  width:50px; height:50px; z-index:9999;
}
.mobile-menu .mobile-menu-container {
  position:relative; width:50px; height:50px; transition:all 0.2s ease;
}
.mobile-menu .mobile-menu-container:after {
  content:''; transition:all 0.2s ease; transform:scale(1); transform-origin:center;
  display:block; width:50px; height:50px; background:#fec013;
  border-radius:50%; position:absolute; top:0; right:0; z-index:1;
}
.mobile-menu.open { width:200px; height:500px; }
.mobile-menu.open .mobile-menu-container { width:200px; float:right; height:500px; }
.mobile-menu.open .mobile-menu-container:after { transform:scale(22); }
.mobile-menu.open .mobile-menu-content { width:200px; height:500px; }
.mobile-menu.open .nav-icon { box-shadow:none; }
.mobile-menu.open .nav-icon:before { transform:translateY(8px) rotate(135deg); }
.mobile-menu.open .nav-icon:after { transform:translateY(-8px) rotate(-135deg); }
.mobile-menu.open .nav-icon span { transform:scale(0); }
.mobile-menu .mobile-menu-content {
  z-index:3; position:relative; padding-top:50px; text-align:right;
  width:50px; height:0; overflow:hidden; transition:all 0.2s ease;
}
.mobile-menu .menu-list { width:180px; }
.mobile-menu .menu-list li .mobile-menu-link,
.mobile-menu .menu-list li .mobile-menu-item {
  color:#fff; text-decoration:none; font-weight:400; margin-bottom:7px;
  display:block; font-size:1.25em; padding-right:10px; font-family:'open_sansregular'; white-space:nowrap;
}
.mobile-menu .menu-list .sub-menu { padding-right:0.5em; font-size:0.98em; }
.mobile-menu .menu-list .sub-menu li .mobile-menu-link { font-size:0.95em; }
.mobile-menu .nav-icon {
  position:fixed; top:20px; right:10px; width:50px; height:50px;
  padding:0; margin:0; background:#fec013; padding:10px;
  border:none; border-radius:50%; z-index:9; box-shadow:0 0 28px -11px #262626;
  transition:all 0.2s ease;
}
.mobile-menu .nav-icon:after, .mobile-menu .nav-icon:before, .mobile-menu .nav-icon span {
  background-color:#252525; border-radius:5px; content:''; display:block;
  height:2px; margin:6px 0; transition:all 0.2s ease;
}

/* ============================================
   HERO / TOP BANNER
   ============================================ */
.top-small-banner { position:relative; }
.top-small-banner img { width:100%; display:block; }
.top-small-banner .post-image { display:block; height:336px; overflow:hidden; }
.top-small-banner .post-image img { width:100%; height:100%; object-fit:cover; }

/* ============================================
   TITLE (Porady heading)
   ============================================ */
.title { margin-bottom:40px; position:relative; padding:0 0 20px; }
.title:after {
  content:''; width:55px; height:5px; background:#fec013;
  display:block; border-radius:30px; margin:30px auto 0;
}
.container-title {
  font-family:'playfair_displayregular'; color:#262626; text-align:center;
  font-size:36px; line-height:normal; margin-bottom:10px;
}

/* ============================================
   POSTS LISTING (index.php)
   ============================================ */
.padding-medium { padding:100px 0; }
.posts-container {
  padding:20px 10px; display:flex;
}
.posts-container .posts-set { margin:0 15px; flex:1; }
.posts-container .post {
  margin:30px 0; padding:40px 40px 5px;
  border:1px solid #ebeef3; border-radius:4px;
  box-shadow:0 0 0 rgba(0,0,0,0.25); background-color:#fff;
  transition:box-shadow 0.6s cubic-bezier(0.23,1,0.32,1);
}
.posts-container .post:hover { box-shadow:0 20px 70px rgba(0,0,0,0.12); }
.posts-container .post img { width:100%; height:100%; object-fit:cover; border-radius:4px; }
.posts-container .post .post-content { padding:25px 0 80px; position:relative; }
.posts-container .post .post-title {
  font-size:23px; margin-bottom:15px; color:#262626; line-height:1.1; font-family:'playfair_displayregular';
}
.posts-container .post .post-text { text-align:justify; color:#8d8d8d; line-height:1.6; }
.post-container { text-decoration:none; }

/* Post avatar */
.post-avatar {
  position:absolute; bottom:25px; left:0; display:flex; align-items:center;
}
.post-avatar img { width:35px !important; border-radius:50%; }
.post-avatar .post-author {
  display:block; margin-left:15px; text-transform:uppercase;
  font-size:14px; font-weight:600; color:#262626;
}

/* ============================================
   SINGLE POST
   ============================================ */
.post-main-contant .post-content { text-align:justify; }
.post-main-contant .post-content p,
.post-main-contant .post-content ul,
.post-main-contant .post-content li { margin:15px 0; }
.post-main-contant .post-content ul,
.post-main-contant .post-content ol { list-style:initial; padding-left:30px; }
.post-main-contant .post-content li:not(:last-of-type) { margin-bottom:8px; }
.post-main-contant .post-content h2 { font-size:25px; margin:30px 0; font-family:'playfair_displayregular'; }
.post-main-contant .post-content a { font-weight:600; text-decoration:none; color:#262626; font-family:'open_sanssemibold' !important; }
.post-main-contant .post-content img { max-width:100%; border-radius:4px; }
.post-main-contant .post-avatar { position:static; justify-content:center; margin-bottom:70px; }
.post-main-contant .post-image { margin:15px 0; }
.post-main-contant .post-image img { width:100%; border-radius:4px; }

/* ============================================
   FOOTER
   ============================================ */
.footer {
  background:url('https://pollyart.pl/static/images/footer-bg.jpg') top left no-repeat;
  background-size:cover; background-attachment:fixed;
  padding:170px 20px 40px; box-sizing:border-box;
}
.footer-content .footer-title {
  font-size:43px; color:#fff; font-family:'playfair_displayregular';
  line-height:normal; margin-bottom:20px;
}
.footer-content .footer-grid { display:flex; flex-wrap:wrap; }

/* Footer form */
.footer-content .contact-us-form {
  width:415px; max-width:95%; display:flex; flex-direction:column; margin-top:60px;
}
.footer-content .contact-us-form input[type='text'],
.footer-content .contact-us-form textarea {
  margin-bottom:40px; background:none; border:none;
  border-bottom:1px solid #fff; padding:10px 5px;
  font-size:16px; color:#fff; font-weight:300; transition:all 0.2s ease; width:90%;
}
.footer-content .contact-us-form textarea { padding:0 5px; line-height:normal; }
.footer-content .contact-us-form input[type='text']:focus,
.footer-content .contact-us-form textarea:focus { border-bottom:1px solid #fec013; }
.footer-content .contact-us-form input::placeholder,
.footer-content .contact-us-form textarea::placeholder { color:#fff; opacity:1; }
.footer-content .contact-us-form .rodo-accept { color:#fff; font-weight:300; font-size:10px; line-height:1.6; }
.footer-content .contact-us-form .rodo-accept a { color:#fff; text-decoration:none; font-weight:400; }
.footer-content .contact-us-form .button {
  margin-top:30px; padding:13px; text-transform:uppercase; font-weight:300;
}

/* Buttons */
.button {
  background:#fec013; border:none; border-radius:var(--default-border-radius);
  padding:8px 20px; color:#252525; font-size:16px; transition:all 0.2s ease;
  text-decoration:none; display:inline-block; line-height:1.1; cursor:pointer;
}
.button:hover { background:#fff !important; color:#fec013 !important; }
.button.round-50 { border-radius:var(--default-border-radius); }

/* Checkboxes */
.checkbox-container { position:relative; }
.checkbox-container label { display:flex; align-items:center; gap:10px; }
.checkbox-container input[type="checkbox"] {
  position:absolute; top:5px; left:0; opacity:0; width:16px; height:16px; padding:0 !important;
}
.checkbox-container .custom-checkbox {
  width:15px; min-width:15px; height:15px; aspect-ratio:1;
  border:1px solid #fec013; border-radius:1px; position:relative;
}
.checkbox-container .custom-checkbox .check {
  position:absolute; top:40%; left:50%;
  transform:translate(-50%,-50%) rotate(-50deg);
  width:65%; height:40%; border-radius:1px;
  border-bottom:2px solid #fec013; border-left:2px solid #fec013;
  transition:150ms ease; opacity:0;
}
.checkbox-container input:checked + .custom-checkbox .check { opacity:1; }
.checkbox-container .checkbox-text { font-size:16px; font-family:'open_sansregular'; }
.checbkoxes-container span, .checbkoxes-container span a { font-size:12px; font-weight:400; }

/* Footer contact info */
.footer-content .contact-info { margin-left:100px; }
.footer-content .contact-info span { display:inline-block; margin-right:25px; }
.footer-content .contact-info span img { width:50px; height:60px; }

.contact-info .contact-line {
  display:flex; color:#fff; font-weight:300; font-size:16px; margin-bottom:25px;
}
.contact-info .contact-line ul li { color:#fff; }
.contact-info .contact-line.facebook { margin-bottom:40px; }
.contact-info .contact-line.facebook a { width:50px; text-align:center; }
.contact-info .contact-line .nip { margin-top:15px; }

/* Social list in footer */
.social-list { list-style:none; display:flex; margin:0 0 40px; }
.social-list li { margin:0 30px 0 0; }

/* Good spot */
.contact-good-spot { max-width:85px; }
.contact-good-spot a {
  display:flex; width:100%; white-space:nowrap; align-items:flex-end;
  text-decoration:none;
}
.contact-good-spot img { max-width:100%; }
.contact-good-spot span { color:#fff; text-decoration:none; display:inline-block; margin-bottom:30px; margin-left:25px; }

/* Footer navigation */
.footer-navigation-container { display:flex; gap:60px; margin-left:auto; }
.footer-navigation-column { }
.footer-navigation-title { color:#fff; font-weight:600; font-size:16px; margin-bottom:15px; font-family:'open_sanssemibold'; }
.footer-navigation-column ul { list-style:disc; padding-left:20px; }
.footer-navigation-column ul li { margin-bottom:8px; }
.footer-navigation-column ul li a { color:#fff; text-decoration:none; font-size:14px; font-weight:300; }
.footer-navigation-column ul li a:hover { text-decoration:underline; }

/* Footer bottom */
.footer-bottom { margin-top:50px; display:flex; justify-content:space-between; align-items:flex-end; }
.footer-bottom a { text-decoration:none; color:#898989; }
.copy { color:#898989; font-family:'open_sansregular'; line-height:1.8; }
.copy .color { color:#ffc105; }
.copy .color b { font-family:'open_sanssemibold'; }

/* ============================================
   VALUATION FORM (in single posts)
   ============================================ */
.valuation-section { background:#f3f2f2; padding:80px 20px; text-align:center; }
.valuation-section .section-title {
  font-size:36px; color:#262626; font-family:'playfair_displayregular'; margin-bottom:40px;
}
.valuation-section .valuation-form { max-width:800px; margin:0 auto; }
.valuation-section .valuation-checkboxes { display:flex; flex-wrap:wrap; justify-content:center; gap:30px; margin-bottom:30px; }
.valuation-section .valuation-group { text-align:left; }
.valuation-section .valuation-group h4 { font-family:'playfair_displaybold'; font-size:20px; margin-bottom:10px; }
.valuation-section .valuation-type { margin-bottom:10px; font-size:16px; font-weight:300; }
.valuation-section .form-fields { display:flex; flex-wrap:wrap; gap:15px; justify-content:center; margin-top:20px; }
.valuation-section .form-fields input {
  border:none; border-bottom:2px solid #ddd; border-radius:0;
  padding:10px; max-width:250px; background:none; font-size:16px;
}
.valuation-section .form-fields input:focus { border-bottom-color:#fec013; }

/* Other posts section */
.inne-posty { padding:60px 20px; }
.inne-posty h3 { font-family:'playfair_displayregular'; font-size:28px; text-align:center; margin-bottom:30px; }
.inne-posty .posts-grid { display:flex; flex-wrap:wrap; gap:20px; justify-content:center; }
.inne-posty .post-card { width:calc(33.333% - 20px); min-width:280px; }
.inne-posty .post-card a { text-decoration:none; color:#262626; }
.inne-posty .post-card img { width:100%; border-radius:4px; height:200px; object-fit:cover; }
.inne-posty .post-card h4 { font-size:18px; margin-top:10px; font-family:'playfair_displayregular'; line-height:1.2; }

/* ============================================
   RESPONSIVE
   ============================================ */
@media screen and (max-width:1260px) {
  .main-navbar nav { justify-content:center; }
  .menu { display:none; }
  .mobile-menu { display:block; }
  .main-navbar { padding-top:10px; }
}

@media screen and (max-width:960px) {
  .footer-content .footer-grid { flex-direction:column; align-items:flex-start; padding:0 25px; }
  .footer-content .contact-info { margin-left:0; margin-top:40px; }
  .footer-navigation-container { margin-left:0; margin-top:40px; }
  .footer-bottom { flex-direction:column; align-items:flex-start; }
  .footer { background-attachment:initial !important; }
}

@media screen and (max-width:769px) {
  .posts-container { flex-direction:column; }
  .title { margin-bottom:0; padding:20px; }
  .padding-medium { padding:50px 0; }
  .container-title { font-size:29px; }
  .footer-content .footer-grid { flex-direction:column; }
  .footer-navigation-container { flex-direction:column; gap:30px; }
  .contact-good-spot a { margin-left:0 !important; }
  .footer-content .contact-us-form { width:100%; max-width:100%; }
}

@media screen and (max-width:540px) {
  .main-navbar nav { justify-content:flex-start; padding:0 20px; }
  .top-small-banner img { min-height:150px; object-fit:cover; }
  .top-small-banner .post-image { height:150px; }
  .footer { padding:100px 10px;
    background:url('https://pollyart.pl/static/images/footer-bg-tel.jpg') top left no-repeat;
    background-size:cover;
  }
  .footer-content .footer-title { font-size:32px; }
}

/* Sticky wycena button on scroll */
.main-navbar.fixed .menu-action-btn {
  position:fixed; top:-60px; opacity:0; right:50px;
  transition:all 0.5s ease 0s, opacity 0.3s ease 0.1s;
  background:#fec013 !important; color:#252525 !important;
}
.main-navbar.pulldown .menu-action-btn {
  opacity:1; position:fixed; top:30px; right:50px;
}

/* Valuation Modal */
.valuation-modal {
  display:flex; width:100%; position:fixed; top:0; left:0; height:100vh;
  z-index:-1; background:#fff; align-items:center; justify-content:center;
  opacity:0; visibility:hidden; transition:all 0.2s ease;
}
.valuation-modal.show { opacity:1; visibility:visible; z-index:9999; }
.valuation-modal .valuation-title {
  display:block; font-size:35px; color:#262626; text-align:center;
  margin-bottom:10px; font-family:'playfair_displaybold'; line-height:normal;
}
.valuation-modal .valuation-subtitle {
  font-family:'playfair_displaybold'; font-size:25px; font-weight:300;
  display:block; margin-bottom:15px;
}
.valuation-modal .hide-valuation {
  position:absolute; top:5%; right:5%; border:none; font-size:40px;
  background:#fff; font-weight:300; display:block; padding:5px; cursor:pointer;
}
.valuation-modal .valuation-form {
  display:flex; flex-direction:column; align-items:center;
}
.valuation-modal .valuation-checkboxes-grid {
  display:flex; flex-wrap:wrap; justify-content:center; gap:20px;
  margin:20px 0 30px; padding:10px 25px;
}
.valuation-modal .valuation-group { min-width:200px; }
.valuation-modal .valuation-type { margin-bottom:15px; font-size:18px; font-weight:300; }
.valuation-modal .valuation-input {
  margin-bottom:25px; border:none; border-bottom:2px solid #ddd;
  border-radius:0; max-width:250px; width:100%; padding:10px;
  background:none; font-size:16px; outline:none;
}
.valuation-modal .valuation-input:focus { border-bottom-color:#fec013; }

/* Pagination */
.blog-pagination {
  text-align:center; padding:40px 0 20px; font-family:'open_sansregular';
}
.blog-pagination a, .blog-pagination span {
  display:inline-block; padding:8px 16px; margin:0 4px;
  border-radius:var(--default-border-radius); text-decoration:none;
  font-size:16px; transition:all 0.2s ease;
}
.blog-pagination a {
  color:#262626; border:1px solid #ddd;
}
.blog-pagination a:hover {
  background:#fec013; color:#252525; border-color:#fec013;
}
.blog-pagination span.current {
  background:#fec013; color:#252525; border:1px solid #fec013;
}
.blog-pagination span.dots {
  border:none; padding:8px 8px;
}

/* Mobile fixes */
@media screen and (max-width:769px) {
  .posts-container .post .post-text { text-align:left; }
  .posts-container .post { padding:20px 20px 5px; }
  .posts-container .posts-set { margin:0 5px; }
  .post-main-contant .post-content { text-align:left; }
}
@media screen and (max-width:540px) {
  .main-container.padding-medium { padding:30px 10px; }
  .posts-container { padding:10px 0; }
  .posts-container .post .post-title { font-size:19px; }
  .posts-container .post .post-text { font-size:14px; }
  .blog-pagination { padding:20px 0; }
}

/* CookieYes mobile fix */
@media screen and (max-width:769px) {
  .cky-consent-container {
    top:auto !important; bottom:0 !important;
    left:0 !important; right:0 !important;
    transform:none !important;
    box-shadow:0px -3px 10px rgba(0,0,0,0.3) !important;
    max-width:100% !important; width:100% !important;
  }
}

/* ============================================================
   TYPOGRAFIA TRESCI POSTU (.single-content)
   ============================================================ */
.single-content {
  font-family: 'open_sanslight';
  font-size: 17px;
  line-height: 1.75;
  color: #262626;
  word-wrap: break-word;
}

.single-content > *:first-child { margin-top: 0; }
.single-content > *:last-child { margin-bottom: 0; }

/* Paragrafy */
.single-content p {
  margin: 0 0 1.4em 0;
  line-height: 1.75;
}

/* Naglowki - wyrazne odstepy ktore oddzielaja sekcje */
.single-content h2 {
  font-family: 'playfair_displaybold';
  font-size: 1.85em;
  line-height: 1.25;
  margin: 2.2em 0 0.7em 0;
  color: #1a1a1a;
  font-weight: normal;
}
.single-content h3 {
  font-family: 'playfair_displayregular';
  font-size: 1.45em;
  line-height: 1.3;
  margin: 2em 0 0.6em 0;
  color: #1a1a1a;
  font-weight: normal;
}
.single-content h4 {
  font-family: 'open_sanssemibold';
  font-size: 1.15em;
  line-height: 1.35;
  margin: 1.8em 0 0.5em 0;
  color: #1a1a1a;
}

/* Naglowek na poczatku nie powinien miec gornego marginesu (duplikuje go wrap) */
.single-content h2:first-child,
.single-content h3:first-child,
.single-content h4:first-child { margin-top: 0; }

/* Pogrubienia - explicit, zeby bold byl widoczny */
.single-content strong,
.single-content b {
  font-family: 'open_sanssemibold';
  font-weight: 600;
  color: #1a1a1a;
}

/* Italic */
.single-content em,
.single-content i { font-style: italic; }

/* Linki */
.single-content a {
  color: #262626;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
  transition: opacity 0.15s ease;
}
.single-content a:hover { opacity: 0.6; }

/* Listy */
.single-content ul,
.single-content ol {
  margin: 0 0 1.4em 0;
  padding-left: 1.6em;
}
.single-content li {
  margin-bottom: 0.5em;
  line-height: 1.7;
}
.single-content li > ul,
.single-content li > ol { margin: 0.5em 0 0 0; }

/* Cytaty */
.single-content blockquote {
  margin: 1.8em 0;
  padding: 0.8em 0 0.8em 1.5em;
  border-left: 3px solid #262626;
  font-style: italic;
  color: #555;
  font-size: 1.05em;
}
.single-content blockquote p:last-child { margin-bottom: 0; }

/* Obrazki w tresci */
.single-content img {
  max-width: 100%;
  height: auto;
  display: block;
  margin: 1.8em auto;
  border-radius: 4px;
}
.single-content figure {
  margin: 1.8em 0;
}
.single-content figure img { margin: 0 auto; }
.single-content figcaption {
  font-size: 0.85em;
  color: #7a7a7a;
  text-align: center;
  margin-top: 0.6em;
  font-style: italic;
}

/* Tabele */
.single-content table {
  width: 100%;
  border-collapse: collapse;
  margin: 1.6em 0;
  font-size: 0.95em;
}
.single-content th,
.single-content td {
  padding: 0.7em 0.9em;
  border-bottom: 1px solid #e5e5e5;
  text-align: left;
}
.single-content th {
  font-family: 'open_sanssemibold';
  background: #fafafa;
}

/* Kod inline i blok */
.single-content code {
  background: #f4f4f4;
  padding: 2px 6px;
  border-radius: 3px;
  font-size: 0.92em;
  font-family: 'SF Mono', Monaco, Consolas, monospace;
}
.single-content pre {
  background: #f4f4f4;
  padding: 1em 1.2em;
  border-radius: 4px;
  overflow-x: auto;
  margin: 1.4em 0;
  line-height: 1.55;
}
.single-content pre code {
  background: none;
  padding: 0;
}

/* Horyzontalna linia jako separator sekcji */
.single-content hr {
  border: none;
  border-top: 1px solid #e5e5e5;
  margin: 2.5em 0;
}

/* Responsive - mniejszy tekst na mobile */
@media screen and (max-width: 768px) {
  .single-content { font-size: 16px; }
  .single-content h2 { font-size: 1.55em; margin-top: 1.8em; }
  .single-content h3 { font-size: 1.3em; margin-top: 1.6em; }
  .single-content ul,
  .single-content ol { padding-left: 1.3em; }
  .single-content blockquote { padding-left: 1em; }
}

/* ============================================================
   SEKCJA "INNE POSTY" pod pojedynczym wpisem
   ============================================================ */
.related-posts {
  margin-top: 56px;
  padding-top: 40px;
  border-top: 1px solid #e8e8e8;
}

.related-posts-title {
  font-family: 'playfair_displayregular';
  font-size: 1.55em;
  margin: 0 0 24px 0;
  color: #1a1a1a;
  font-weight: normal;
  text-align: center;
}

.related-posts-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}

.related-post-card {
  display: flex;
  gap: 14px;
  padding: 14px;
  border: 1px solid #e8e8e8;
  border-radius: 10px;
  text-decoration: none !important;
  color: inherit !important;
  background: #fff;
  transition: all 0.2s ease;
  align-items: center;
  overflow: hidden;
}

.related-post-card:hover {
  border-color: #c0c0c0;
  background: #fafafa;
  transform: translateY(-2px);
  box-shadow: 0 4px 14px rgba(0,0,0,0.06);
  text-decoration: none !important;
  opacity: 1 !important;
}

.related-post-thumb {
  width: 88px;
  height: 66px;
  border-radius: 6px;
  overflow: hidden;
  flex-shrink: 0;
  background: #f5f5f5;
}

.related-post-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  margin: 0 !important;
  border-radius: 0 !important;
}

.related-post-content {
  flex: 1;
  min-width: 0;
}

.related-post-label {
  display: inline-block;
  font-family: 'open_sansregular';
  font-size: 0.7rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #999;
  margin-bottom: 4px;
}

.related-post-title {
  font-family: 'open_sanssemibold';
  font-size: 0.95rem;
  line-height: 1.4;
  color: #1a1a1a;
  text-decoration: none !important;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.related-post-card:hover .related-post-title {
  color: #000;
}

@media (max-width: 640px) {
  .related-posts-grid {
    grid-template-columns: 1fr;
  }
  .related-post-thumb {
    width: 72px;
    height: 54px;
  }
  .related-post-title {
    font-size: 0.9rem;
  }
}

/* ============================================================
   KARTA AUTORA pod pojedynczym wpisem
   ============================================================ */
.post-author-card {
  margin-top: 56px;
  padding: 32px;
  background: linear-gradient(135deg, #fafafa 0%, #f5f5f5 100%);
  border-radius: 14px;
  border: 1px solid #e8e8e8;
}

.post-author-info {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 20px;
}

.post-author-avatar {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
  border: 2px solid #fff;
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
}

.post-author-text {
  flex: 1;
  min-width: 0;
}

.post-author-name {
  font-family: 'open_sanssemibold';
  font-size: 1.1rem;
  color: #1a1a1a;
  line-height: 1.3;
}

.post-author-role {
  font-family: 'open_sansregular';
  font-size: 0.85rem;
  color: #777;
  margin-top: 2px;
}

.post-author-contacts {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.post-author-chip {
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
  padding: 9px 16px;
  background: #fff;
  border: 1px solid #e0e0e0;
  border-radius: 99px;
  font-family: 'open_sansregular';
  font-size: 0.85rem;
  color: #1a1a1a !important;
  text-decoration: none !important;
  transition: all 0.2s ease;
  line-height: 1;
}

.post-author-chip:hover {
  background: #1a1a1a;
  color: #fff !important;
  border-color: #1a1a1a;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(0,0,0,0.12);
  opacity: 1 !important;
}

.post-author-chip .chip-icon {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  stroke: currentColor;
}

@media (max-width: 640px) {
  .post-author-card {
    padding: 24px 20px;
  }
  .post-author-contacts {
    gap: 8px;
  }
  .post-author-chip {
    padding: 8px 12px;
    font-size: 0.8rem;
  }
}

/* ==========================================
   Listing - ujednolicone proporcje thumbnaili
   (obsluguje zarowno stare obrazki 2000x1333 jak i nowe 1024x1024 z n8n)
   ========================================== */
.post-image-container img,
.post-container .post-image img {
    aspect-ratio: 16 / 9;
    object-fit: cover;
    width: 100%;
    height: auto;
    display: block;
}
