/* =========================================================
   Zakwas i Sól — piekarnia na zakwasie, Kraków (Kazimierz)
   Rękodzielniczy CSS, bez frameworków.
   Paleta: mąka/krem #f6efe2 · skórka #8a5a2b · żytni #3a2c1d · oliwka #6b7050
   ========================================================= */

:root{
  --maka:#f6efe2;
  --maka-ciemna:#ece0cb;
  --skorka:#8a5a2b;
  --skorka-jasna:#c98a4e;
  --zytni:#3a2c1d;
  --zytni-mietki:#5a4632;
  --oliwka:#6b7050;
  --oliwka-ciemna:#525739;
  --krem:#fffaf0;
  --linia:#d8c8ac;
  --cien:0 10px 28px rgba(58,44,29,.14);
  --cien-mocny:0 18px 44px rgba(58,44,29,.22);
  --rad:14px;
  --max:none;
  --gutter:clamp(20px, 5.5vw, 96px);
  --prose:64ch;
  --serif:"Source Serif 4", Georgia, "Times New Roman", serif;
  --recznie:"Caveat", "Comic Sans MS", cursive;
  --sans:-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
/* Zabezpieczenie przed przypadkowym przewijaniem w poziomie na wąskich ekranach */
html,body{overflow-x:clip;max-width:100%;}
/* Elementy siatki/flex mogą się kurczyć poniżej swojej zawartości (obrazy itp.) */
.hero-in>*,.dwie-kolumny>*,.kontakt-grid>*,.siatka>*{min-width:0;}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--zytni);
  line-height:1.68;
  font-size:17px;
  background-color:var(--maka);
  /* "mączna" ziarnista tekstura tła: delikatny szum + ciepły gradient */
  background-image:
    radial-gradient(circle at 18% 12%, rgba(201,138,78,.10), transparent 42%),
    radial-gradient(circle at 86% 78%, rgba(107,112,80,.09), transparent 46%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E");
  background-attachment:fixed, fixed, scroll;
}

img{max-width:100%;display:block;}
a{color:var(--skorka);text-decoration:none;}
a:hover{text-decoration:underline;}

h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.18;color:var(--zytni);margin:0 0 .5em;}
h1{font-size:clamp(2.1rem,5vw,3.4rem);letter-spacing:-.01em;}
h2{font-size:clamp(1.7rem,3.6vw,2.4rem);}
h3{font-size:1.28rem;}
p{margin:0 0 1.1em;}

/* Full-width: sekcje ciągną się na całą szerokość ekranu,
   a treść oddycha dzięki płynnym marginesom bocznym (clamp). */
.kontener{width:100%;max-width:none;margin:0;padding-inline:var(--gutter);}
/* Bloki czysto tekstowe trzymają komfortową długość wiersza mimo pełnej szerokości */
.proza,.dokument,.sek-naglowek,.hero-lead{max-width:var(--prose);}
.sek-naglowek{max-width:54ch;}

.recznie{font-family:var(--recznie);color:var(--skorka);}
.skreslone{text-decoration:line-through;color:var(--zytni-mietki);}

/* ---------- Przyciski ---------- */
.btn{
  display:inline-block;font-family:var(--sans);font-weight:600;font-size:1rem;
  padding:14px 26px;border-radius:40px;cursor:pointer;border:2px solid transparent;
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease;
  text-decoration:none;line-height:1;
}
.btn:hover{text-decoration:none;transform:translateY(-2px);}
.btn-glowny{background:var(--skorka);color:var(--krem);box-shadow:var(--cien);}
.btn-glowny:hover{background:#76491f;box-shadow:var(--cien-mocny);}
.btn-pusty{background:transparent;color:var(--zytni);border-color:var(--zytni);}
.btn-pusty:hover{background:var(--zytni);color:var(--maka);}

/* ---------- Nagłówek / nawigacja ---------- */
.top{
  position:sticky;top:0;z-index:50;
  background:rgba(246,239,226,.92);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--linia);
}
.top-in{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:12px var(--gutter);max-width:none;margin:0;}
.marka{display:flex;align-items:center;gap:11px;}
.marka img{width:42px;height:42px;}
.marka b{font-family:var(--serif);font-size:1.32rem;color:var(--zytni);letter-spacing:-.01em;}
.marka span{display:block;font-family:var(--recznie);font-size:1.05rem;color:var(--oliwka);line-height:.9;margin-top:2px;}
.marka:hover{text-decoration:none;}

.menu{display:flex;align-items:center;gap:6px;list-style:none;margin:0;padding:0;}
.menu a{color:var(--zytni);font-weight:500;padding:9px 13px;border-radius:8px;font-size:.98rem;}
.menu a:hover{background:var(--maka-ciemna);text-decoration:none;}
.menu a.aktywne{color:var(--skorka);font-weight:700;}
.menu .btn{margin-left:8px;padding:11px 20px;}

.burger{display:none;background:none;border:0;cursor:pointer;padding:8px;}
.burger span{display:block;width:26px;height:2.6px;background:var(--zytni);margin:5px 0;border-radius:2px;transition:.25s;}
.burger.open span:nth-child(1){transform:translateY(7.6px) rotate(45deg);}
.burger.open span:nth-child(2){opacity:0;}
.burger.open span:nth-child(3){transform:translateY(-7.6px) rotate(-45deg);}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;}
.hero-in{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;padding-block:74px 64px;}
.hero-eyebrow{font-family:var(--recznie);font-size:1.7rem;color:var(--oliwka);display:inline-block;transform:rotate(-3deg);margin-bottom:6px;}
.hero h1{margin-bottom:.35em;}
.hero-lead{font-size:1.18rem;color:var(--zytni-mietki);max-width:30em;}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:26px;}
.hero-foto{position:relative;}
.hero-foto img{width:100%;height:480px;object-fit:cover;border-radius:18px;box-shadow:var(--cien-mocny);}
.plomba{
  position:absolute;bottom:-18px;left:-18px;background:var(--krem);
  border:2px dashed var(--skorka-jasna);border-radius:14px;padding:12px 18px;
  box-shadow:var(--cien);transform:rotate(-4deg);
}
.plomba .recznie{font-size:1.9rem;line-height:.9;display:block;}
.plomba small{color:var(--zytni-mietki);font-size:.82rem;}

/* ---------- Sekcje ---------- */
section{padding:60px 0;}
.sek-naglowek{max-width:42em;margin-bottom:34px;}
.sek-naglowek .recznie{font-size:1.5rem;display:block;transform:rotate(-2deg);}
.sek-naglowek p{color:var(--zytni-mietki);}
.tlo-krem{background:var(--krem);border-top:1px solid var(--linia);border-bottom:1px solid var(--linia);}
.tlo-zytni{background:var(--zytni);color:var(--maka);}
.tlo-zytni h2,.tlo-zytni h3{color:var(--maka);}
.tlo-zytni p{color:#e6d8c2;}

/* ---------- Grafik (tabela) ---------- */
.grafik{width:100%;border-collapse:collapse;background:var(--krem);border-radius:var(--rad);overflow:hidden;box-shadow:var(--cien);}
.grafik caption{text-align:left;font-family:var(--recznie);font-size:1.4rem;color:var(--oliwka);padding:0 0 10px;}
.grafik th,.grafik td{padding:14px 18px;text-align:left;border-bottom:1px solid var(--linia);vertical-align:top;}
.grafik thead th{background:var(--oliwka);color:var(--krem);font-family:var(--sans);font-weight:600;font-size:.95rem;}
.grafik tbody th{font-family:var(--serif);font-weight:600;width:160px;color:var(--skorka);}
.grafik tr:last-child td,.grafik tr:last-child th{border-bottom:0;}
.grafik tr.wolne td{color:var(--zytni-mietki);font-style:italic;}
.grafik tr:hover td,.grafik tr:hover th{background:var(--maka);}

/* ---------- Karty chlebów ---------- */
.siatka{display:grid;gap:26px;}
.siatka.k2{grid-template-columns:repeat(2,1fr);}
.siatka.k3{grid-template-columns:repeat(3,1fr);}
.siatka.k4{grid-template-columns:repeat(4,1fr);}
.karta{
  background:var(--krem);border:1px solid var(--linia);border-radius:var(--rad);
  overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--cien);
  transition:transform .18s ease, box-shadow .18s ease;
}
.karta:hover{transform:translateY(-5px);box-shadow:var(--cien-mocny);}
.karta-foto{height:200px;overflow:hidden;}
.karta-foto img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease;}
.karta:hover .karta-foto img{transform:scale(1.06);}
.karta-tresc{padding:18px 20px 22px;display:flex;flex-direction:column;gap:8px;flex:1;}
.karta-tresc h3{margin:0;}
.karta-sklad{font-size:.92rem;color:var(--zytni-mietki);flex:1;}
.karta-cena{font-family:var(--serif);font-weight:600;font-size:1.18rem;color:var(--skorka);}
.znak{display:inline-block;font-size:.76rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;
  background:var(--maka-ciemna);color:var(--zytni-mietki);padding:3px 10px;border-radius:20px;width:fit-content;}

/* ---------- O zakwasie / proza ---------- */
.proza{max-width:42em;}
.proza p:first-of-type::first-letter{font-family:var(--serif);font-size:3.1rem;float:left;line-height:.8;padding:6px 10px 0 0;color:var(--skorka);}
.dwie-kolumny{display:grid;grid-template-columns:1.1fr .9fr;gap:46px;align-items:center;}

/* ---------- Opinie ---------- */
.opinia{
  background:var(--krem);border-left:4px solid var(--oliwka);border-radius:0 var(--rad) var(--rad) 0;
  padding:24px 26px;box-shadow:var(--cien);
}
.opinia blockquote{margin:0 0 14px;font-size:1.12rem;font-family:var(--serif);font-style:italic;color:var(--zytni);}
.opinia .kto{display:flex;align-items:center;gap:12px;}
.opinia .kto img{width:46px;height:46px;border-radius:50%;object-fit:cover;}
.opinia .kto b{display:block;}
.opinia .kto small{color:var(--zytni-mietki);}

/* ---------- FAQ ---------- */
.faq details{
  background:var(--krem);border:1px solid var(--linia);border-radius:var(--rad);
  padding:6px 22px;margin-bottom:14px;box-shadow:var(--cien);
}
.faq summary{cursor:pointer;font-family:var(--serif);font-weight:600;font-size:1.12rem;padding:14px 0;list-style:none;display:flex;justify-content:space-between;gap:14px;}
.faq summary::-webkit-details-marker{display:none;}
.faq summary::after{content:"+";color:var(--skorka);font-size:1.5rem;line-height:1;transition:.2s;}
.faq details[open] summary::after{transform:rotate(45deg);}
.faq details p{padding-bottom:14px;margin:0;color:var(--zytni-mietki);}

/* ---------- Kontakt / godziny ---------- */
.kontakt-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;}
.godziny{list-style:none;margin:0;padding:0;}
.godziny li{display:flex;justify-content:space-between;gap:14px;padding:11px 0;border-bottom:1px dashed var(--linia);}
.godziny li:last-child{border-bottom:0;}
.godziny .dzis{color:var(--skorka);font-weight:700;}
.dane-firmy{background:var(--krem);border:1px solid var(--linia);border-radius:var(--rad);padding:22px 24px;box-shadow:var(--cien);}
.dane-firmy dt{font-weight:600;color:var(--oliwka-ciemna);margin-top:10px;font-size:.9rem;text-transform:uppercase;letter-spacing:.03em;}
.dane-firmy dd{margin:2px 0 0;}

/* ---------- Formularz ---------- */
form.zamow{display:grid;gap:16px;background:var(--krem);border:1px solid var(--linia);border-radius:var(--rad);padding:26px;box-shadow:var(--cien);}
.pole{display:flex;flex-direction:column;gap:6px;}
.pole label{font-weight:600;font-size:.94rem;}
.pole input,.pole select,.pole textarea{
  font-family:var(--sans);font-size:1rem;padding:12px 14px;border:1.6px solid var(--linia);
  border-radius:10px;background:var(--maka);color:var(--zytni);
}
.pole input:focus,.pole select:focus,.pole textarea:focus{outline:2px solid var(--skorka-jasna);border-color:var(--skorka);}
.pole textarea{min-height:110px;resize:vertical;}
.zgoda{display:flex;gap:10px;align-items:flex-start;font-size:.9rem;color:var(--zytni-mietki);}
.zgoda input{margin-top:4px;}

/* ---------- Pasek z deadlinem ---------- */
.deadline{
  display:flex;flex-wrap:wrap;align-items:center;gap:18px;justify-content:space-between;
  background:var(--oliwka);color:var(--krem);border-radius:var(--rad);padding:24px 30px;box-shadow:var(--cien);
}
.deadline .recznie{color:var(--maka);font-size:1.8rem;line-height:1;}
.deadline p{margin:6px 0 0;color:#eef0e3;}
.deadline .btn-glowny{background:var(--krem);color:var(--zytni);}
.deadline .btn-glowny:hover{background:#fff;}

/* ---------- Treść stron prawnych ---------- */
.dokument{max-width:48em;}
.dokument h2{margin-top:1.6em;}
.dokument h3{margin-top:1.3em;}
.dokument ul,.dokument ol{margin:0 0 1.2em;padding-left:1.3em;}
.dokument li{margin-bottom:.4em;}
.aktualizacja{font-size:.9rem;color:var(--zytni-mietki);font-style:italic;}

/* ---------- Strona podziękowania ---------- */
.dziekuje{text-align:center;padding:96px 0;}
.dziekuje .recznie{font-size:2.4rem;color:var(--oliwka);display:block;margin-bottom:8px;}

/* ---------- Stopka ---------- */
.stopka{background:var(--zytni);color:#e6d8c2;padding:54px 0 28px;}
.stopka a{color:var(--maka);}
.stopka-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px;margin-bottom:34px;}
.stopka h4{color:var(--maka);font-size:1.05rem;margin-bottom:14px;}
.stopka ul{list-style:none;margin:0;padding:0;}
.stopka li{margin-bottom:9px;}
.stopka .marka b{color:var(--maka);}
.stopka .marka span{color:var(--skorka-jasna);}
.stopka-dol{border-top:1px solid #5a4632;padding-top:20px;font-size:.86rem;display:flex;flex-wrap:wrap;gap:8px 20px;justify-content:space-between;color:#c9b89e;}
.stopka-nip{font-size:.84rem;color:#bda985;margin-top:8px;}

/* ---------- Responsywność ---------- */
/* Bardzo szerokie ekrany: karty same dobierają szerokość, brak rozjazdu */
@media(min-width:1500px){
  .siatka.k4{grid-template-columns:repeat(4,minmax(0,1fr));}
  .hero-in{gap:64px;}
}

/* Tablet poziomo */
@media(max-width:1100px){
  .hero-in{gap:38px;}
  .siatka.k4{grid-template-columns:repeat(2,1fr);}
}

/* Tablet pionowo */
@media(max-width:900px){
  .hero-in{grid-template-columns:1fr;gap:32px;padding-block:56px 48px;}
  .hero-foto img{height:auto;aspect-ratio:4/3;}
  .hero-lead{max-width:none;}
  .dwie-kolumny,.kontakt-grid{grid-template-columns:1fr;gap:30px;}
  .dwie-kolumny .hero-foto{order:-1;}
  .siatka.k3{grid-template-columns:repeat(2,1fr);}
  .stopka-grid{grid-template-columns:1fr 1fr;gap:28px;}
  section{padding:52px 0;}
}

/* Telefon */
@media(max-width:680px){
  .burger{display:block;}
  .menu{
    position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;
    background:var(--maka);border-bottom:1px solid var(--linia);padding:10px 16px 18px;gap:2px;
    display:none;box-shadow:var(--cien);
  }
  .menu.open{display:flex;}
  .menu a{padding:13px 12px;border-bottom:1px solid var(--linia);}
  .menu .btn{margin:10px 0 0;text-align:center;}
  .top-in{position:relative;}
  .siatka.k4,.siatka.k3,.siatka.k2{grid-template-columns:1fr;}
  .stopka-grid{grid-template-columns:1fr;}
  .grafik tbody th{width:auto;}
  .deadline{flex-direction:column;align-items:flex-start;}
  section{padding:44px 0;}
}

/* Małe telefony: tabela grafiku przewija się poziomo zamiast łamać układ */
@media(max-width:520px){
  .grafik-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;}
  .grafik{min-width:460px;}
  .plomba{left:auto;right:-6px;bottom:-14px;}
  h1{font-size:clamp(1.9rem,8vw,2.4rem);}
}
