/* ========== Wyspy Zaczarowane — motyw ========== */
* { box-sizing: border-box; }
body { margin: 0; background: var(--bg); color: var(--ink); font-family: var(--font-body); line-height: 1.6; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; background: none; border: none; cursor: pointer; padding: 0; }
img { max-width: 100%; height: auto; }
::selection { background: var(--red); color: var(--bg); }

.container { max-width: 1280px; margin: 0 auto; padding: 0 40px; }
@media (max-width: 768px) { .container { padding: 0 20px; } }
.center { text-align: center; }

.serif { font-family: var(--font-display); }
.italic { font-style: italic; }
.mono { font-family: var(--font-mono); letter-spacing: 0.12em; text-transform: uppercase; font-size: 11px; }
.gold { color: var(--gold); }
.red { color: var(--red); }
.sub { color: var(--sub); }

.title-xl { font-family: var(--font-display); font-weight: 500; font-size: clamp(40px, 6vw, 88px); line-height: 0.95; letter-spacing: -0.01em; margin: 20px 0; }
.title-lg { font-family: var(--font-display); font-weight: 500; font-size: clamp(32px, 4vw, 56px); line-height: 1.02; margin: 14px 0; }
.title-md { font-family: var(--font-display); font-weight: 500; font-size: clamp(24px, 2.6vw, 36px); line-height: 1.1; margin: 12px 0; }

.eyebrow { display: inline-flex; align-items: center; gap: 10px; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--gold); }
.eyebrow::before { content: ''; width: 24px; height: 1px; background: var(--gold); }
.divider-fleuron { display: flex; align-items: center; justify-content: center; gap: 14px; color: var(--gold); font-family: var(--font-display); font-size: 20px; margin: 40px 0; }
.divider-fleuron::before, .divider-fleuron::after { content: ''; height: 1px; flex: 1; background: var(--rule); max-width: 140px; }

.btn { display: inline-flex; align-items: center; gap: 10px; padding: 14px 24px; background: var(--ink); color: var(--bg); font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; border: 1px solid var(--ink); transition: all .2s; cursor: pointer; }
.btn:hover { background: var(--red); border-color: var(--red); color: #FBF8F1; }
.btn-ghost { display: inline-flex; align-items: center; gap: 10px; padding: 13px 22px; background: transparent; color: var(--ink); font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; border: 1px solid var(--ink); cursor: pointer; }
.btn-ghost:hover { background: var(--ink); color: var(--bg); }

input, textarea, select { font: inherit; color: inherit; background: transparent; border: 1px solid var(--rule); padding: 12px 14px; outline: none; }
input:focus, textarea:focus, select:focus { border-color: var(--ink); }

/* Topbar */
.topbar { background: var(--ink); color: var(--bg); padding: 8px 0; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; }
.topbar-inner { display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.topbar-accent { color: var(--gold); }
@media (max-width: 720px) {
  .topbar-inner > span:first-child, .topbar-inner > span:last-child { display: none; }
  .topbar-inner { justify-content: center; }
}

/* Header */
.site-header { border-bottom: 1px solid var(--rule); background: var(--bg); position: sticky; top: 0; z-index: 50; }
.header-inner { display: flex; align-items: center; justify-content: space-between; padding: 20px 40px; gap: 32px; }
.site-brand { display: inline-flex; }
.wyspy-logo { display: inline-flex; align-items: center; gap: 14px; }
.wyspy-logo-text { display: flex; flex-direction: column; line-height: 1.05; }
.wyspy-logo-name { font-size: 22px; font-weight: 500; }
.wyspy-logo-tag { color: var(--red); margin-top: 6px; font-size: 9px; letter-spacing: 0.4em; }
.primary-menu { display: flex; gap: 28px; list-style: none; margin: 0; padding: 0; }
.primary-menu a { font-size: 14px; padding-bottom: 4px; border-bottom: 1px solid transparent; }
.primary-menu a:hover, .primary-menu .current-menu-item a { color: var(--red); border-bottom-color: var(--red); }
.header-cart { display: flex; align-items: center; gap: 10px; }
.wyspy-cart-count { background: var(--red); color: #FBF8F1; border-radius: 20px; min-width: 22px; height: 22px; display: inline-flex; align-items: center; justify-content: center; font-size: 10px; font-family: var(--font-mono); }
.wyspy-cart-count[data-empty="1"] { display: none; }

/* Hero */
.hero { padding: 80px 0 60px; border-bottom: 1px solid var(--rule); }
.hero-cover-grid { display: grid; grid-template-columns: 1.1fr 1fr; gap: 80px; align-items: center; }
.hero-desc { font-family: var(--font-display); font-style: italic; color: var(--sub); font-size: 22px; margin-top: 8px; }
.hero-excerpt { margin-top: 32px; max-width: 460px; font-size: 17px; line-height: 1.7; color: var(--sub); }
.hero-actions { margin-top: 40px; display: flex; gap: 14px; flex-wrap: wrap; }
.hero-actions.center { justify-content: center; }
.hero-cover { display: flex; justify-content: center; }

.hero-manifesto { padding: 120px 0 100px; text-align: center; }
.hero-manifesto h1 { max-width: 900px; margin: 0 auto; }
.hero-manifesto p { margin-top: 40px; max-width: 560px; margin-left: auto; margin-right: auto; font-size: 18px; color: var(--sub); font-style: italic; }

.hero-collage { overflow: hidden; padding: 60px 0 80px; }
.hero-collage-head { text-align: center; margin-bottom: 48px; }
.hero-collage-head p { margin-top: 24px; max-width: 560px; margin-left: auto; margin-right: auto; font-size: 17px; color: var(--sub); }
.hero-collage-stack { position: relative; height: 420px; margin-top: 40px; }
.collage-book { position: absolute; transition: transform .3s; display: inline-block; }
.collage-book:hover { transform: rotate(0deg) translateY(-8px) !important; }

/* Cover */
.book-cover { position: relative; box-shadow: 0 12px 32px -12px rgba(0,0,0,0.35), 0 2px 6px rgba(0,0,0,0.2); }
.cover-new-badge { position: absolute; top: 8px; right: -6px; background: var(--red); color: #FBF8F1; font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.2em; padding: 4px 8px; text-transform: uppercase; }

/* Book grid */
.book-grid { display: grid; gap: 40px; row-gap: 64px; }
.book-grid.cols-3 { grid-template-columns: repeat(3, 1fr); }
.book-grid.cols-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 900px) { .book-grid.cols-3, .book-grid.cols-4 { grid-template-columns: repeat(2, 1fr); } }

.book-card { display: flex; flex-direction: column; align-items: flex-start; }
.book-card-cover { transition: transform .3s; }
.book-card-cover:hover { transform: translateY(-4px); }
.book-card-meta { margin-top: 18px; }
.book-card-title { font-size: 20px; margin: 6px 0 4px; font-weight: 500; line-height: 1.2; }
.book-card-sub { font-size: 14px; color: var(--sub); }
.book-card-footer { margin-top: 12px; display: flex; justify-content: space-between; align-items: center; width: 100%; }
.wyspy-price, .wyspy-price .woocommerce-Price-amount { font-family: var(--font-display); font-size: 18px; font-weight: 500; }
.add_to_cart_button { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--ink); border-bottom: 1px solid var(--ink); padding-bottom: 2px; }
.add_to_cart_button:hover { color: var(--red); border-color: var(--red); }

/* Book list view */
.book-list { display: flex; flex-direction: column; }
.book-list-row { display: grid; grid-template-columns: 100px 1fr auto auto; gap: 32px; align-items: center; padding: 24px 0; border-top: 1px solid var(--rule); }
.book-list-row:last-child { border-bottom: 1px solid var(--rule); }
.book-list-row h3 { font-size: 22px; margin: 4px 0 2px; font-weight: 500; }
.book-list-meta .italic { font-size: 15px; }

/* Sections */
.bestsellers, .new-releases { padding: 80px 0; }
.section-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 40px; }
.section-head.center { justify-content: center; flex-direction: column; text-align: center; margin-bottom: 56px; }

/* Authors */
.authors-section { background: var(--panel); padding: 100px 0; border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); }
.authors-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; margin-top: 40px; }
@media (max-width: 768px) { .authors-grid { grid-template-columns: 1fr; } }
.author-card { padding: 40px; background: var(--bg); border: 1px solid var(--rule); position: relative; }
.author-card::before { content: ''; position: absolute; top: -1px; left: -1px; right: -1px; height: 2px; background: var(--gold); }
.author-card-head { display: flex; align-items: flex-start; gap: 20px; margin-bottom: 20px; }
.author-card-head h3 { font-size: 30px; margin: 6px 0 0; font-weight: 500; font-family: var(--font-display); }
.author-portrait { width: 88px; height: 88px; background: var(--ink); border: 1px solid var(--gold); display: flex; align-items: center; justify-content: center; flex-shrink: 0; position: relative; }
.author-portrait::before { content: ''; position: absolute; inset: 4px; border: 1px solid var(--gold); opacity: 0.5; }
.author-portrait span { font-family: var(--font-display); font-style: italic; font-size: 32px; color: var(--gold); }
.author-tags { margin-top: 20px; display: flex; flex-wrap: wrap; gap: 8px; }
.author-tags span { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; padding: 5px 10px; border: 1px solid var(--rule); color: var(--sub); }

/* Manifesto */
.manifesto-section { padding: 120px 0; margin: 0; }
.manifesto-section.manifesto-dark { background: var(--ink); color: var(--bg); }
.manifesto-section.manifesto-dark + .site-footer,
.site-main > .manifesto-section.manifesto-dark:last-child { margin-bottom: 0; }
body.home .site-footer { margin-top: 0; }
.manifesto-section.manifesto-light { background: var(--bg); color: var(--ink); border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); }
.manifesto-section.manifesto-paper { background: var(--paper); color: var(--ink); }
.manifesto-grid { display: grid; grid-template-columns: 1fr 2fr; gap: 80px; align-items: start; }
.manifesto-rule { margin-top: 40px; width: 60px; height: 1px; background: var(--gold); }
.manifesto-date { margin-top: 40px; font-family: var(--font-display); font-style: italic; font-size: 14px; color: var(--gold); }
.manifesto-section h2 { font-family: var(--font-display); font-weight: 500; font-size: 44px; line-height: 1.15; margin: 0; }
.manifesto-section p { margin-top: 32px; font-size: 17px; line-height: 1.7; opacity: 0.75; max-width: 640px; }

/* Footer */
.site-footer { background: var(--ink); color: var(--bg); padding: 80px 0 40px; margin-top: 0; }
.footer-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 48px; }
@media (max-width: 800px) { .footer-grid { grid-template-columns: 1fr 1fr; } }
.footer-brand .wyspy-logo-name { color: #FBF8F1; }
.footer-brand .wyspy-logo-tag { color: var(--gold); }
.footer-desc { margin-top: 24px; color: rgba(255,255,255,0.65); line-height: 1.7; max-width: 320px; font-size: 14px; }
.site-footer ul { list-style: none; margin: 20px 0 0; padding: 0; display: grid; gap: 12px; }
.site-footer ul a { color: rgba(255,255,255,0.7); font-size: 14px; }
.site-footer ul a:hover { color: var(--gold); }
.site-footer h4 { margin: 0; color: var(--gold); font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; font-family: var(--font-mono); }
.footer-meta { margin-top: 80px; padding-top: 24px; border-top: 1px solid rgba(255,255,255,0.1); display: flex; justify-content: space-between; align-items: center; color: rgba(255,255,255,0.5); }

/* Pages */
.page-content { padding: 60px 40px 100px; }
.page-head { margin-bottom: 40px; }
.about-hero { background: var(--panel); border-bottom: 1px solid var(--rule); padding: 100px 0; }
.about-block { padding: 80px 40px; border-top: 1px solid var(--rule); display: grid; grid-template-columns: 1fr 2fr; gap: 80px; }
.about-specs { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; }

.upcoming-list { margin-top: 64px; }
.upcoming-row { display: grid; grid-template-columns: 160px 1fr auto; gap: 40px; align-items: center; padding: 40px 0; border-top: 1px solid var(--rule); }
.upcoming-row:last-child { border-bottom: 1px solid var(--rule); }
.upcoming-cta { display: flex; flex-direction: column; gap: 8px; align-items: flex-end; }

.events-list { margin-top: 56px; }
.event-row { display: grid; grid-template-columns: 120px 1fr auto; gap: 40px; align-items: center; padding: 32px 0; border-top: 1px solid var(--rule); }
.event-row:last-child { border-bottom: 1px solid var(--rule); }
.event-date .serif { font-size: 44px; font-weight: 500; line-height: 1; }
.event-title { font-size: 22px; font-weight: 500; }

.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; }
@media (max-width: 800px) { .contact-grid { grid-template-columns: 1fr; } }
.contact-list { margin-top: 48px; display: flex; flex-direction: column; gap: 28px; }
.contact-list .serif { font-size: 18px; margin-top: 6px; }
.contact-form { border: 1px solid var(--rule); padding: 40px; background: var(--panel); display: grid; gap: 18px; }
.contact-form label { display: grid; gap: 6px; }

/* Shop */
.shop-head { background: var(--panel); border-bottom: 1px solid var(--rule); padding: 60px 0 50px; }
.shop-filters { border-bottom: 1px solid var(--rule); background: var(--bg); position: sticky; top: 73px; z-index: 10; }
.shop-filters-inner { display: flex; gap: 24px; align-items: center; padding: 18px 40px; flex-wrap: wrap; justify-content: space-between; }
.shop-layout-switcher { display: flex; gap: 18px; }
.shop-layout-switcher a { color: var(--sub); padding-bottom: 4px; border-bottom: 1px solid transparent; }
.shop-layout-switcher a.active { color: var(--ink); border-bottom-color: var(--red); }
.shop-body { padding: 60px 40px; }
.book-grid.editorial { column-gap: 64px; row-gap: 80px; }

/* Single product */
.single-product-wyspy { padding: 50px 40px 100px; }
.back-link { color: var(--sub); display: inline-block; margin-bottom: 40px; }
.product-grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: 80px; }
@media (max-width: 800px) { .product-grid { grid-template-columns: 1fr; } }
.product-cover-wrap { display: flex; justify-content: center; padding: 20px 0; }
.product-sub { font-size: 22px; color: var(--sub); }
.product-author { margin-top: 20px; font-size: 18px; }
.product-author span { border-bottom: 1px solid var(--ink); padding-bottom: 2px; }
.product-price-row { margin-top: 36px; display: flex; gap: 20px; align-items: baseline; }
.product-price { font-size: 40px; font-weight: 500; }
.tabs-strip { margin-top: 56px; border-bottom: 1px solid var(--rule); display: flex; gap: 32px; }
.tabs-strip .tab { padding-bottom: 14px; color: var(--sub); border-bottom: 2px solid transparent; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; }
.tabs-strip .tab.active { color: var(--ink); border-bottom-color: var(--red); }
.tab-panel { padding-top: 24px; font-size: 16px; line-height: 1.8; color: var(--sub); }
.details-dl > div { display: grid; grid-template-columns: 180px 1fr; padding: 12px 0; border-bottom: 1px solid var(--rule); margin: 0; }
.details-dl dt { color: var(--sub); }
.details-dl dd { margin: 0; }
.review-quote { margin: 0 0 28px; border-left: 2px solid var(--gold); padding-left: 20px; }
.review-quote .italic { font-size: 20px; line-height: 1.5; }

/* Woo Quantity + add to cart on product page */
.cart { margin-top: 28px; display: flex; gap: 14px; align-items: center; flex-wrap: wrap; }
.quantity input { width: 70px; text-align: center; padding: 12px 8px; }
button.single_add_to_cart_button { padding: 14px 24px; background: var(--ink); color: var(--bg); font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; border: 1px solid var(--ink); cursor: pointer; }
button.single_add_to_cart_button:hover { background: var(--red); border-color: var(--red); }

/* Woo cart/checkout — let Woo defaults render, just inherit theme tokens */
.woocommerce table.shop_table { border: 1px solid var(--rule); border-collapse: collapse; }
.woocommerce .cart_totals, .woocommerce-checkout-review-order-table { font-family: var(--font-body); }

/* ========== NEWS TICKER ========== */
.news-ticker { background: var(--ink); color: var(--paper); overflow: hidden; border-top: 1px solid rgba(255,255,255,0.08); border-bottom: 1px solid rgba(255,255,255,0.08); }
.news-ticker-track { display: inline-flex; gap: 48px; padding: 14px 0; white-space: nowrap; animation: wyspy-ticker 60s linear infinite; will-change: transform; }
.news-ticker:hover .news-ticker-track { animation-play-state: paused; }
.news-ticker-item { font-family: var(--font-mono, 'JetBrains Mono', monospace); font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(255,255,255,0.88); }
.news-ticker-plus { color: var(--gold); font-weight: 700; margin-right: 10px; }
@keyframes wyspy-ticker {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}
@media (prefers-reduced-motion: reduce) {
  .news-ticker-track { animation: none; }
}

/* ========== RESPONSIVE ========== */
@media (max-width: 1024px) {
  .container { padding: 0 24px; }
  .hero-cover-grid { grid-template-columns: 1fr; gap: 40px; text-align: center; }
  .hero-excerpt { margin-left: auto; margin-right: auto; }
  .hero-actions { justify-content: center; }
  .manifesto-grid { grid-template-columns: 1fr; gap: 32px; }
  .manifesto-section h2 { font-size: 32px; }
  .about-block { padding: 48px 24px; grid-template-columns: 1fr; gap: 24px; }
  .single-product-wyspy { padding: 30px 24px 60px; }
  .product-grid { gap: 48px; }
  .shop-body, .page-content { padding: 40px 24px 60px; }
  .shop-filters { position: static; }
}

@media (max-width: 768px) {
  .header-inner { padding: 14px 20px; gap: 12px; flex-wrap: wrap; }
  .primary-nav { order: 3; width: 100%; overflow-x: auto; border-top: 1px solid var(--rule); padding-top: 10px; }
  .primary-menu { gap: 18px; flex-wrap: nowrap; white-space: nowrap; }
  .primary-menu a { font-size: 13px; }
  .wyspy-logo svg { width: 40px; height: 40px; }
  .wyspy-logo-name { font-size: 18px; }
  .wyspy-logo-tag { font-size: 8px; }

  .hero { padding: 40px 0; }
  .hero-manifesto { padding: 60px 0; }
  .hero-collage-stack { height: 340px; }
  .collage-book svg, .collage-book .book-cover { width: 140px !important; height: 210px !important; }

  .book-grid.cols-3, .book-grid.cols-4 { grid-template-columns: repeat(2, 1fr); gap: 24px; row-gap: 40px; }
  .book-card-title { font-size: 17px; }
  .book-card-sub { font-size: 13px; }
  .book-card-footer { flex-direction: column; align-items: flex-start; gap: 8px; }

  .book-list-row { grid-template-columns: 80px 1fr; gap: 16px; }
  .book-list-row .wyspy-price, .book-list-row .btn { grid-column: 2; justify-self: start; }

  .bestsellers, .new-releases, .authors-section, .manifesto-section { padding: 56px 0; }
  .section-head { flex-direction: column; align-items: flex-start; gap: 12px; margin-bottom: 28px; }
  .author-card { padding: 24px; }
  .author-card-head h3 { font-size: 24px; }
  .author-portrait { width: 64px; height: 64px; }
  .author-portrait span { font-size: 24px; }
  .about-specs { grid-template-columns: 1fr; gap: 24px; }

  .upcoming-row { grid-template-columns: 1fr; gap: 16px; text-align: center; }
  .upcoming-cover { justify-self: center; }
  .upcoming-cta { align-items: center; }
  .event-row { grid-template-columns: 1fr; gap: 10px; text-align: center; padding: 20px 0; }
  .event-date .serif { font-size: 32px; }
  .contact-form { padding: 24px; }

  .shop-filters-inner { padding: 12px 20px; gap: 14px; }
  .shop-layout-switcher { flex-wrap: wrap; gap: 12px; }

  .product-grid { grid-template-columns: 1fr; gap: 32px; }
  .product-cover-wrap .book-cover { width: 220px !important; height: 330px !important; }
  .product-price { font-size: 32px; }
  .tabs-strip { gap: 18px; flex-wrap: wrap; }

  .footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
  .footer-meta { margin-top: 48px; flex-direction: column; gap: 8px; text-align: center; }
  .site-footer { padding: 56px 0 32px; }

  .title-xl { font-size: clamp(32px, 9vw, 48px); }
  .title-lg { font-size: clamp(26px, 7vw, 36px); }
}

@media (max-width: 480px) {
  .book-grid.cols-3, .book-grid.cols-4 { grid-template-columns: 1fr; }
  .book-card { align-items: center; text-align: center; }
  .hero-actions { flex-direction: column; }
  .hero-actions .btn, .hero-actions .btn-ghost { width: 100%; justify-content: center; }
  .footer-grid { grid-template-columns: 1fr; }
}
