:root {
  --amber-50: #fffbeb;
  --amber-100: #fef3c7;
  --amber-200: #fde68a;
  --amber-300: #fcd34d;
  --amber-400: #fbbf24;
  --amber-500: #f59e0b;
  --amber-600: #d97706;
  --amber-700: #b45309;
  --amber-800: #92400e;
  --amber-900: #78350f;
  --teal-400: #2dd4bf;
  --teal-500: #14b8a6;
  --teal-600: #0d9488;
  --teal-700: #0f766e;
  --teal-800: #115e59;
  --cyan-500: #06b6d4;
  --cyan-600: #0891b2;
  --cyan-700: #0e7490;
  --stone-50: #fafaf9;
  --stone-100: #f5f5f4;
  --stone-200: #e7e5e4;
  --stone-300: #d6d3d1;
  --stone-500: #78716c;
  --stone-700: #44403c;
  --stone-800: #292524;
  --stone-900: #1c1917;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { font-family: "Cormorant Garamond", Georgia, serif; color: var(--stone-800); background: var(--amber-50); line-height: 1.6; font-size: 17px; }
img { max-width: 100%; height: auto; display: block; }
a { color: var(--cyan-700); text-decoration: none; transition: color .2s; }
a:hover { color: var(--amber-700); }

/* ---- NAGŁÓWEK ---- */
.topbar { background: linear-gradient(90deg, var(--cyan-700), var(--teal-700)); color: #fef3c7; font-size: 14px; padding: 6px 0; letter-spacing: .3px; }
.topbar .wrap { display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px; }
.topbar a { color: var(--amber-200); }
.topbar a:hover { color: #fff; }
.wrap { max-width: 1280px; margin: 0 auto; padding: 0 20px; }

header.site { background: rgba(255,255,255,.97); border-bottom: 1px solid var(--amber-200); position: sticky; top: 0; z-index: 50; backdrop-filter: blur(8px); }
header.site .wrap { display: flex; align-items: center; justify-content: space-between; padding: 14px 20px; }
.brand { display:flex; align-items:center; gap:14px; }
.brand-logo { width:54px; height:54px; border-radius: 50%; background: linear-gradient(135deg, var(--amber-400), var(--amber-700)); display:flex; align-items:center; justify-content:center; box-shadow: 0 4px 16px rgba(180,83,9,.3); }
.brand-logo span { font-family: "Playfair Display", Georgia, serif; font-size: 1.5rem; color: #fff; font-weight: 700; letter-spacing: 1px; }
.brand-text h1 { font-family: "Playfair Display", Georgia, serif; font-size: 1.7rem; font-weight: 700; color: var(--amber-800); letter-spacing: 1.5px; line-height: 1; }
.brand-text small { color: var(--cyan-700); font-size: 12px; letter-spacing: 2px; text-transform: uppercase; }
nav.main { display:flex; align-items:center; gap: 6px; }
nav.main a { padding: 10px 16px; font-family: "Cormorant Garamond", serif; font-size: 1.15rem; color: var(--stone-700); letter-spacing: .5px; border-radius: 4px; transition: all .2s; }
nav.main a:hover, nav.main a.active { color: var(--amber-700); background: var(--amber-100); }
.cart-btn { background: var(--amber-600); color: #fff !important; padding: 10px 16px !important; border-radius: 22px; font-weight: 600; box-shadow: 0 4px 14px rgba(180,83,9,.3); display:inline-flex; align-items:center; gap:8px; }
.cart-btn:hover { background: var(--amber-700) !important; transform: translateY(-1px); }
.cart-count { background:#fff; color: var(--amber-700); padding: 1px 8px; border-radius: 12px; font-size: 13px; font-weight: 700; min-width: 22px; text-align:center; }

/* ---- HERO ---- */
.hero { background: linear-gradient(135deg, #fef3c7 0%, #fde68a 35%, #fbbf24 60%, #0e7490 100%); color: #fff; padding: 90px 0 110px; position: relative; overflow: hidden; }
.hero::before, .hero::after { content:""; position:absolute; border-radius: 50%; opacity: .25; }
.hero::before { width: 400px; height: 400px; background: var(--amber-300); top: -100px; right: -100px; filter: blur(80px); }
.hero::after { width: 350px; height: 350px; background: var(--teal-500); bottom: -80px; left: -80px; filter: blur(80px); }
.hero .wrap { position: relative; z-index: 1; text-align: center; max-width: 800px; }
.hero h2 { font-family: "Playfair Display", Georgia, serif; font-size: clamp(2.2rem, 5vw, 3.6rem); color: var(--stone-900); margin-bottom: 20px; line-height: 1.15; font-weight: 700; text-shadow: 0 2px 12px rgba(255,251,235,.5); }
.hero .lead { font-size: 1.3rem; color: var(--stone-800); margin-bottom: 36px; font-style: italic; }
.hero .cta-row { display:flex; gap: 16px; justify-content:center; flex-wrap:wrap; }
.btn { display: inline-block; padding: 14px 32px; border-radius: 30px; font-weight: 600; letter-spacing: .5px; transition: all .25s; text-align: center; cursor:pointer; border:none; font-family: inherit; font-size: 1.05rem; }
.btn-amber { background: var(--amber-600); color: #fff; box-shadow: 0 6px 20px rgba(180,83,9,.4); }
.btn-amber:hover { background: var(--amber-700); transform: translateY(-2px); color: #fff; box-shadow: 0 10px 24px rgba(180,83,9,.5); }
.btn-teal { background: var(--cyan-700); color: #fff; box-shadow: 0 6px 20px rgba(14,116,144,.4); }
.btn-teal:hover { background: var(--teal-800); transform: translateY(-2px); color: #fff; }
.btn-outline { background: transparent; color: var(--amber-700); border: 2px solid var(--amber-600); }
.btn-outline:hover { background: var(--amber-600); color: #fff; }
.btn-ghost { background: transparent; color: var(--stone-700); }
.btn-ghost:hover { color: var(--amber-700); }
.btn-block { display:block; width:100%; }

/* ---- SEKCJE ---- */
section.section { padding: 80px 0; }
section.section.light { background: var(--stone-50); }
section.section.amber-bg { background: linear-gradient(180deg, var(--amber-50), var(--amber-100)); }
h2.section-title { font-family: "Playfair Display", Georgia, serif; font-size: 2.3rem; color: var(--amber-800); margin-bottom: 16px; text-align:center; }
.section-sub { text-align:center; color: var(--stone-500); margin-bottom: 50px; font-size: 1.15rem; font-style: italic; }

/* ---- KAFELKI KATEGORII ---- */
.kategorie-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 24px; }
.kat-card { background: #fff; border-radius: 16px; overflow: hidden; box-shadow: 0 6px 24px rgba(120,53,15,.08); transition: all .3s; border: 1px solid var(--amber-100); }
.kat-card:hover { transform: translateY(-4px); box-shadow: 0 14px 36px rgba(120,53,15,.18); }
.kat-card-img { height: 220px; background:#fff; display:flex; align-items:center; justify-content:center; position:relative; overflow:hidden; padding: 20px; }
.kat-card-img::after { content:""; position:absolute; inset:0; background: linear-gradient(0deg, rgba(120,53,15,.4) 0%, transparent 100%); }
.kat-icon { font-size: 4.5rem; opacity: .85; }
.kat-card-body { padding: 22px; }
.kat-card-body h3 { font-family: "Playfair Display", serif; font-size: 1.5rem; color: var(--amber-800); margin-bottom: 8px; }
.kat-card-body p { color: var(--stone-500); font-size: .98rem; margin-bottom: 14px; min-height: 50px; }
.kat-card-body .kat-count { color: var(--cyan-700); font-weight: 600; font-size: .9rem; }

/* ---- KAFELKI PRODUKTÓW ---- */
.produkty-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 28px; }
.prod-card { background: #fff; border-radius: 14px; overflow: hidden; box-shadow: 0 4px 16px rgba(120,53,15,.06); transition: all .3s; border: 1px solid var(--stone-200); display:flex; flex-direction:column; }
.prod-card:hover { transform: translateY(-4px); box-shadow: 0 16px 36px rgba(120,53,15,.18); border-color: var(--amber-300); }
.prod-card-img { aspect-ratio: 1; background: #fff; padding: 14px; position: relative; }
.prod-card-img img { width: 100%; height: 100%; object-fit: contain; }
.badge { position:absolute; top:14px; padding: 4px 12px; border-radius: 14px; font-size: .8rem; font-weight: 700; letter-spacing: .5px; text-transform: uppercase; }
.badge-wyr { right:14px; background: var(--amber-600); color: #fff; }
.badge-nowy { left:14px; background: var(--cyan-600); color: #fff; }
.badge-promo { left:14px; background: #dc2626; color:#fff; }
.prod-card-body { padding: 18px 18px 22px; display:flex; flex-direction:column; flex:1; }
.prod-card-body h3 { font-family: "Playfair Display", serif; font-size: 1.15rem; color: var(--stone-900); margin-bottom: 6px; line-height: 1.3; min-height: 2.6em; }
.prod-card-body .kategoria-label { color: var(--cyan-700); font-size: .82rem; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 10px; }
.prod-cena { font-family: "Playfair Display", serif; font-size: 1.45rem; color: var(--amber-700); font-weight: 700; margin-top: auto; margin-bottom: 12px; }
.prod-cena-promo { color: #dc2626; }
.prod-cena-stara { font-size: 1rem; color: var(--stone-500); text-decoration: line-through; font-weight: 400; margin-left: 6px; }
.prod-card-body .btn { font-size: .92rem; padding: 10px 18px; }

/* ---- KARTA PRODUKTU ---- */
.product-page { display: grid; grid-template-columns: 1.1fr 1fr; gap: 50px; padding: 50px 0; }
.product-galeria { background: #fff; border-radius: 16px; padding: 30px; box-shadow: 0 6px 24px rgba(120,53,15,.08); }
.product-galeria-main { background: #fff; border-radius: 8px; aspect-ratio: 1; display:flex; align-items:center; justify-content:center; }
.product-galeria-main img { max-width: 100%; max-height: 100%; object-fit: contain; }
.product-thumbs { display: grid; grid-template-columns: repeat(auto-fill, minmax(80px, 1fr)); gap: 10px; margin-top: 16px; }
.product-thumb { aspect-ratio:1; border: 2px solid var(--stone-200); border-radius: 6px; padding: 4px; cursor: pointer; background:#fff; }
.product-thumb img { width: 100%; height: 100%; object-fit: contain; }
.product-thumb.active { border-color: var(--amber-600); }
.product-info h1 { font-family: "Playfair Display", serif; font-size: 2.3rem; color: var(--stone-900); margin-bottom: 12px; line-height: 1.15; }
.product-info .kategoria-link { color: var(--cyan-700); text-transform: uppercase; letter-spacing: 1.5px; font-size: .85rem; margin-bottom: 8px; display:inline-block; }
.product-cena-big { font-family: "Playfair Display", serif; font-size: 2.6rem; color: var(--amber-700); font-weight: 700; margin: 22px 0; }
.product-opis-krotki { font-size: 1.15rem; color: var(--stone-700); margin-bottom: 24px; font-style: italic; }
.product-opis-dlugi { background: var(--amber-50); border-left: 4px solid var(--amber-400); padding: 22px 24px; border-radius: 8px; margin-bottom: 30px; white-space: pre-line; }
.qty-add { display: flex; gap: 14px; align-items: center; }
.qty-input { display: flex; border: 2px solid var(--amber-300); border-radius: 26px; overflow: hidden; }
.qty-input button { background: var(--amber-50); border: none; width: 40px; font-size: 1.4rem; cursor: pointer; color: var(--amber-700); }
.qty-input button:hover { background: var(--amber-100); }
.qty-input input { border: none; width: 60px; text-align: center; font-size: 1.1rem; font-weight: 600; background: #fff; }
.qty-add .btn { flex: 1; }

/* ---- KOSZYK ---- */
.koszyk-table { width: 100%; border-collapse: collapse; background:#fff; border-radius: 12px; overflow: hidden; box-shadow: 0 4px 16px rgba(0,0,0,.06); }
.koszyk-table th { background: var(--amber-100); padding: 14px 16px; text-align: left; color: var(--amber-800); font-family: "Playfair Display", serif; font-size: 1.05rem; }
.koszyk-table td { padding: 14px 16px; border-top: 1px solid var(--stone-200); vertical-align: middle; }
.koszyk-table img { width: 70px; height: 70px; object-fit: contain; }
.koszyk-suma { margin-top: 30px; background: #fff; padding: 24px; border-radius: 12px; box-shadow: 0 4px 16px rgba(0,0,0,.06); }
.koszyk-suma .row { display:flex; justify-content:space-between; padding: 8px 0; }
.koszyk-suma .row.total { border-top: 2px solid var(--amber-200); margin-top: 12px; padding-top: 16px; font-size: 1.4rem; font-weight: 700; color: var(--amber-800); }

/* ---- FORMULARZE ---- */
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px 22px; }
.form-field { display: flex; flex-direction: column; gap: 6px; }
.form-field.full { grid-column: 1 / -1; }
.form-field label { font-weight: 600; color: var(--stone-700); font-size: .95rem; }
.form-field input, .form-field textarea, .form-field select { padding: 12px 14px; border: 1.5px solid var(--stone-200); border-radius: 8px; font-family: inherit; font-size: 1rem; background:#fff; transition: border-color .2s; }
.form-field input:focus, .form-field textarea:focus, .form-field select:focus { outline: none; border-color: var(--amber-500); box-shadow: 0 0 0 3px rgba(245,158,11,.15); }
.form-field textarea { min-height: 130px; resize: vertical; }
.honeypot { position: absolute; left: -9999px; }
.choice-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px,1fr)); gap: 12px; }
.choice-card { border: 2px solid var(--stone-200); border-radius: 10px; padding: 14px; cursor:pointer; transition: all .2s; background:#fff; }
.choice-card:hover { border-color: var(--amber-400); }
.choice-card.active { border-color: var(--amber-600); background: var(--amber-50); }
.choice-card strong { display:block; color: var(--amber-800); margin-bottom: 4px; }
.choice-card small { color: var(--stone-500); }
.choice-card input { display:none; }

/* ---- KONTAKT / FOOTER ---- */
.kontakt-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 50px; padding: 30px 0; }
.kontakt-info { background: #fff; padding: 32px; border-radius: 16px; box-shadow: 0 4px 16px rgba(0,0,0,.06); }
.kontakt-info h3 { font-family: "Playfair Display", serif; color: var(--amber-800); margin-bottom: 20px; font-size: 1.5rem; }
.kontakt-info .ki-row { display: flex; gap: 14px; margin-bottom: 18px; align-items: flex-start; }
.kontakt-info .ki-row svg { color: var(--cyan-700); flex-shrink: 0; margin-top: 4px; }
.kontakt-info .ki-row strong { display:block; color: var(--stone-700); font-size: .9rem; text-transform: uppercase; letter-spacing: 1px; }
.kontakt-info .ki-row span { color: var(--stone-800); font-size: 1.1rem; }

footer.site { background: linear-gradient(180deg, var(--stone-800), var(--stone-900)); color: var(--stone-300); padding: 60px 0 30px; margin-top: 80px; }
footer.site h4 { font-family: "Playfair Display", serif; color: var(--amber-300); margin-bottom: 18px; font-size: 1.2rem; }
footer.site a { color: var(--stone-300); }
footer.site a:hover { color: var(--amber-400); }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1.5fr; gap: 40px; padding-bottom: 36px; border-bottom: 1px solid var(--stone-700); }
.footer-grid ul { list-style: none; }
.footer-grid li { padding: 5px 0; }
.footer-bottom { display:flex; justify-content:space-between; padding-top: 24px; font-size: .9rem; color: var(--stone-500); }

/* ---- ALERTS ---- */
.alert { padding: 14px 18px; border-radius: 8px; margin: 16px 0; }
.alert-success { background: #dcfce7; color: #14532d; border-left: 4px solid #16a34a; }
.alert-error { background: #fef2f2; color: #7f1d1d; border-left: 4px solid #dc2626; }
.alert-info { background: var(--amber-50); color: var(--amber-800); border-left: 4px solid var(--amber-500); }

.breadcrumb { padding: 12px 0; font-size: .9rem; color: var(--stone-500); }
.breadcrumb a { color: var(--cyan-700); }
.breadcrumb a:hover { color: var(--amber-700); }

/* ---- RESPONSIVE ---- */
@media (max-width: 900px) {
  .product-page { grid-template-columns: 1fr; }
  .form-grid { grid-template-columns: 1fr; }
  .kontakt-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  nav.main { gap: 2px; }
  nav.main a { padding: 8px 10px; font-size: 1rem; }
  .brand-text h1 { font-size: 1.3rem; }
  header.site .wrap { padding: 10px 16px; }
  .hero { padding: 60px 0 80px; }
  section.section { padding: 50px 0; }
  .koszyk-table th, .koszyk-table td { padding: 8px; font-size: .85rem; }
}
@media (max-width: 520px) {
  .footer-grid { grid-template-columns: 1fr; }
  nav.main a:not(.cart-btn) { display: none; }
  .brand-text small { display: none; }
}

.kat-card-img img.kat-bg { width: 100%; height: 100%; object-fit: contain; transition: transform .4s; }
.kat-card:hover .kat-bg { transform: scale(1.05); }
.kat-card-img::before { content:""; position:absolute; inset:0; background: linear-gradient(0deg, rgba(180,83,9,.1) 0%, transparent 50%); pointer-events:none; }
