/* assets/css/service.css */
/* Styl dla pojedynczej usługi */
:root{
  --bg:#f6f9fb; --card:#fff; --text:#0f1724; --muted:#6b7280;
  --accent:#0ea5a4; --accent-dark:#0b8b84; --shadow:0 6px 20px rgba(12,14,20,0.06);
  --max:1200px; --radius:12px; --font:Inter,system-ui,-apple-system,"Segoe UI",Roboto,Arial;
}
/* ... (podstawowe style body, .container itp. zostają bez zmian) ... */
*{box-sizing:border-box}
html,body{height:100%;margin:0;background:var(--bg);color:var(--text);font-family:var(--font);-webkit-font-smoothing:antialiased}
a{color:inherit}
.container{max-width:var(--max);margin:0 auto;padding:28px 20px}
.card{background:var(--card);padding:20px;border-radius:12px;box-shadow:var(--shadow)}

/* header/cta */
.btn{display:inline-flex;align-items:center;gap:8px;background:var(--accent);color:#fff;padding:10px 14px;border-radius:999px;font-weight:600;border:none;cursor:pointer}
.btn.small{padding:6px 10px;font-size:14px}
.btn.ghost{background:transparent;color:var(--accent-dark);border:1px solid rgba(14,165,164,0.08);box-shadow:none}

/* * ZMODYFIKOWANA SEKCJA HERO 
 * Cała sekcja .hero jest teraz białą kartą.
*/
.hero {
  gap: 24px; /* Odstęp między zdjęciem a panelem */
  /* NOWE STYLE */
  background: var(--card);
  padding: 24px;
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}

.hero-left {
  position: relative;
  border-radius: var(--radius); /* Zaokrąglenie dla samego zdjęcia */
  overflow: hidden;
  /* box-shadow: var(--shadow); <-- USUNIĘTY CIEŃ */
}

.hero-left img {
  width: 100%;
  height: 100%; 
  object-fit: cover; 
  display: block;
}

/* Panel informacji (prawa kolumna) */
.hero-card {
  padding: 24px;
  display: flex;
  flex-direction: column;
  justify-content: space-between; 
  height: 100%; 
  /* NOWE STYLE */
  box-shadow: none !important; /* Usuwa cień z klasy .card, jeśli jest obecna */
}

.kicker {
  font-size: 13px;
  color: var(--accent);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.hero-card h1 {
  font-size: 28px; 
  font-weight: 800;
  margin-top: 4px;
}

.hero-card .muted {
  margin-top: 8px;
  font-size: 15px;
}

/* Siatka dla meta-danych (czas, cena, ...) */
.hero-meta {
  display: grid;
  grid-template-columns: 1fr 1fr; /* Dwie kolumny */
  gap: 14px;
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid #f0f3f6; /* Delikatny separator */
}

.meta-item {
  /* Styl pojedynczej informacji (np. "Czas trwania") */
}

.meta-item strong {
  font-weight: 700;
  font-size: 16px;
  display: block;
}

/* Wyróżnienie ceny */
.meta-item.price-meta .price {
  font-weight: 800;
  font-size: 20px;
  color: var(--text);
}

/* Przyciski CTA na dole panelu */
.ctas {
  margin-top: 24px; /* Odstęp od meta-danych */
  display: flex;
  gap: 12px;
}

/* Badge "Promocja" na zdjęciu */
.promo-badge {
  position: absolute;
  top: 16px;
  left: 16px;
  background: var(--accent);
  color: white;
  padding: 6px 12px;
  border-radius: 999px;
  font-weight: 700;
  font-size: 14px;
  box-shadow: 0 4px 15px rgba(14, 165, 164, 0.3);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  z-index: 10;
}
/* Koniec stylów HERO */


/* main layout (reszta strony) - bez zmian */
.two-col{display:grid;grid-template-columns:1fr 340px;gap:28px;margin-top:28px}

/* ... (reszta stylów: .features, .timeline, .benefits itd. pozostaje bez zmian) ... */
.features{display:flex;gap:12px;flex-wrap:wrap}
.feature{display:flex;gap:12px;align-items:flex-start;background:#fbfdfe;padding:12px;border-radius:10px;min-width:180px}
.feature i{font-size:20px;color:var(--accent)}
.timeline{position:relative;padding-left:18px;border-left:2px dashed rgba(15,23,36,0.06)}
.step{position:relative;padding:18px 12px;margin-bottom:10px}
.step:before{content:'';position:absolute;left:-11px;top:22px;width:14px;height:14px;background:var(--card);border:3px solid var(--accent);border-radius:50%}
.benefits{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}

/* Karta z wymaganiami / ograniczeniami (Nowy styl) */
.notice-card {
  padding: 20px;
  border: 1px solid #f0f3f6;
  margin-bottom: 24px; /* Zastępuje margin-top na reszcie kart */
}
.notice-title {
  font-weight: 700;
  font-size: 16px;
  display: flex;
  align-items: center;
  gap: 8px;
  color: #059669; /* Zielony dla wymagań */
}
.notice-title.danger {
  color: #dc2626; /* Czerwony dla ograniczeń */
}
.notice-card p {
  margin-top: 8px;
  padding-left: 28px; /* Wcięcie tekstu */
}
/* Koniec karty notice */

/* Poprawki marginesów dla kart w głównej treści */
.two-col section > .card {
  margin-top: 24px;
}
.two-col section > .card:first-child {
  margin-top: 0; /* Pierwsza karta (notice) nie ma marginesu */
}


.price-card{padding:18px;border-radius:12px;border:1px solid #eef6f5;background:linear-gradient(180deg,#ffffff,#fbffff)}
.pricing { /* Kontener na karty cenowe */
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 14px;
}

.faq .q{cursor:pointer;padding:14px 12px;border-radius:10px;background:#fbfdfe;margin-bottom:8px;display:flex;justify-content:space-between;align-items:center}
.faq .a{padding:12px 14px;margin-bottom:10px;border-radius:10px;background:#fff;display:none;color:var(--muted)}
.reviews{display:flex;gap:14px;align-items:center; overflow-x: auto; padding-bottom: 10px;}
.review{min-width:260px;padding:18px;border-radius:12px;background:#fff;box-shadow:var(--shadow)}

/* Panel boczny CTA (prawa kolumna) */
.aside-cta {
  display: flex;
  flex-direction: column;
  gap: 12px;
  position: -webkit-sticky; /* Sticky sidebar */
  position: sticky;
  top: 128px; /* Pod headerem (112px + 16px marginesu) */
}
.aside-cta .contact {
  display: flex;
  gap: 12px;
  align-items: center;
}
.aside-cta .phone {
  font-weight: 700;
  font-size: 16px;
}
/* ... (reszta stylów .footer, .modal, .form-row... bez zmian) ... */
.footer{padding:30px 20px;margin-top:40px;text-align:center;color:var(--muted);font-size:14px}
.modal-backdrop{position:fixed;inset:0;background:rgba(2,6,23,0.45);display:none;align-items:center;justify-content:center;z-index:90}
.modal{background:var(--card);padding:20px;border-radius:12px;max-width:520px;width:92%;box-shadow:0 10px 40px rgba(2,6,23,0.4)}
.form-row{display:flex;gap:10px}
input,select,textarea{width:100%;padding:10px;border:1px solid #e6eef0;border-radius:8px}

/* responsiveness */
@media (max-width:980px){
  /* Hero przechodzi na 1 kolumnę (dzięki md: w HTML) */
  .two-col{grid-template-columns:1fr}
  .benefits{grid-template-columns:repeat(2,1fr)}
  .price-card{margin-bottom:10px}
  .aside-cta { position: static; } /* Wyłączamy sticky na mobile */
}
@media (max-width:560px){
  .features{flex-direction:column}
  .benefits{grid-template-columns:1fr}
  .container{padding:18px}
  .hero-card h1{font-size:24px} /* Mniejszy tytuł na mobile */
  .hero-meta { grid-template-columns: 1fr; } /* Meta w jednej kolumnie */
}