/* ======== OBECNÉ SEKCE ======== */
section {
  padding: 5em 0;
  width: 100%;
  background-color: #fff;
}

/* ======== ÚVOD ======== */
/* ======== SLUŽBY ======== */
.sluzby {
  background-color: #fafafa;
  padding: 5em 0;
}

.container-sluzby {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 5%;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 2.5em;
}

.sluzba {
  background-color: #fff;
  border: 1px solid #f2b6d3;
  border-radius: 15px;
  padding: 2.5em;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.05);
  transition: all 0.3s ease;
}

.sluzba:hover {
  transform: translateY(-5px);
  box-shadow: 0 6px 15px rgba(0, 0, 0, 0.1);
}

.sluzba h2 {
  font-family: 'Kaushan Script', cursive;
  color: #a0006d;
  font-size: 1.5rem;
  margin-bottom: 1rem;
}

.sluzba p {
  font-size: 1rem;
  color: #333;
  line-height: 1.7;
}

/* ======== KONTAKT ======== */
.contact {
  background-color: #fff;
}

.container-kontakt form {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.container-kontakt input,
.container-kontakt textarea {
  padding: 1rem;
  border: 1px solid #ccc;
  border-radius: 8px;
  font-size: 1rem;
}

.container-kontakt button {
  align-self: flex-start;
}
/* ======== CENÍK ======== */
.cenik {
  background-color: #fafafa;
}

.cenik .container {
  text-align: center;
}

.cenik h2 {
  margin-bottom: 1.5em;
  font-size: 2rem;
}

.cenik-boxy {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 2em;
  margin-top: 3em;
}

.cenik-box {
  background: #fff;
  border: 1px solid #f2b6d3;
  border-radius: 15px;
  padding: 2em;
  box-shadow: 0 4px 10px rgba(0,0,0,0.05);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.cenik-box:hover {
  transform: translateY(-5px);
  box-shadow: 0 6px 15px rgba(0,0,0,0.1);
}

.cenik-box h3 {
  font-family: 'Kaushan Script', cursive;
  color: #a0006d;
  margin-bottom: 0.5em;
}

.cena {
  font-size: 1.2rem;
  margin-top: 0.5em;
  color: #a0006d;
  font-weight: bold;
}

.pozn {
  margin-top: 3em;
  font-size: 1rem;
}
/* ======== FORMULÁŘ KONTAKT ======== */
.contact h2 {
  font-size: 2rem;
  margin-bottom: 1em;
  text-align: center;
}

.contact p {
  text-align: center;
  margin-bottom: 2em;
}

#kontaktni-formular {
  max-width: 600px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
}

#kontaktni-formular label {
  font-weight: 600;
  color: #a0006d;
}

#kontaktni-formular input,
#kontaktni-formular textarea {
  padding: 1rem;
  border: 1px solid #ccc;
  border-radius: 10px;
  font-size: 1rem;
  transition: border-color 0.2s ease;
}

#kontaktni-formular input:focus,
#kontaktni-formular textarea:focus {
  border-color: #a0006d;
  outline: none;
}
/* ======== BLOG ======== */
.blog {
  background-color: #fafafa;
}

.blog .intro {
  text-align: center;
  margin-bottom: 3em;
  font-size: 1.1rem;
  line-height: 1.7;
}

.blog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 2.5em;
}

.blog-card {
  background-color: #fff;
  border: 1px solid #f2b6d3;
  border-radius: 15px;
  overflow: hidden;
  box-shadow: 0 4px 10px rgba(0,0,0,0.05);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.blog-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 6px 15px rgba(0,0,0,0.1);
}

.blog-card img {
  width: 100%;
  height: 220px;
  object-fit: cover;
}

.blog-content {
  padding: 1.5em;
}

.blog-content h3 {
  color: #a0006d;
  font-family: 'Kaushan Script', cursive;
  margin-bottom: 0.5em;
  font-size: 1.4rem;
}

.blog-content p {
  font-size: 1rem;
  line-height: 1.6;
  margin-bottom: 1em;
  color: #333;
}
/* ======== STRÁNKA 404 ======== */
.not-found {
  background-color: #fff;
  text-align: center;
  padding: 6em 0;
}

.not-found h2 {
  font-size: 2.2rem;
  color: #a0006d;
  margin-bottom: 1em;
}

.not-found p {
  font-size: 1.1rem;
  margin-bottom: 2em;
  line-height: 1.7;
  color: #333;
}

.not-found .buttons {
  display: flex;
  justify-content: center;
  gap: 1.5em;
  flex-wrap: wrap;
}

.not-found .illustration {
  margin-top: 3em;
  font-size: 3rem;
  color: #a0006d;
}

.not-found .cta-button {
  background-color: #a0006d;
  color: #fff;
  padding: 0.8em 1.5em;
  border-radius: 10px;
  transition: background 0.3s ease;
}

.not-found .cta-button:hover {
  background-color: #c8328c;
}


/* ======== RESPONSIVITA ======== */
@media (max-width: 768px) {
  section {
    padding: 3em 0;
  }
  .highlight {
    font-size: 1.1rem;
    padding: 1em;
  }
  header {
    flex-direction: column;
    align-items: flex-start;
  }
  nav ul {
    gap: 1em;
  }
}

/* ======== CENÍK (v2) – scoped styles pro cenik.html v routeru ======== */
.cenik.cenik-v2 { padding: 0; }
.cenik-wrapper { padding: 60px 20px; }

.cenik-wrapper {max-width: 1100px;
        margin: 0 auto;}

.cenik-wrapper h1, .cenik-wrapper h2, .cenik-wrapper h3, .cenik-wrapper h4 {font-family: "Kaushan Script", cursive;
        color: var(--brand-color);
        letter-spacing: 0.5px;
        font-weight: 400;}

.cenik-wrapper .header {text-align: center;
        margin-bottom: 50px;}

.cenik-wrapper .header h2 {font-size: 3rem; margin-bottom: 10px;}

.cenik-wrapper .header p {color: #666; font-size: 1.1rem; max-width: 600px; margin: 0 auto;}

.cenik-wrapper .package-grid {display: grid;
        grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
        gap: 30px;
        margin-bottom: 60px;}

.cenik-wrapper .package-card {background: var(--white);
        border-radius: 15px;
        padding: 40px 30px;
        text-align: center;
        box-shadow: 0 10px 40px rgba(160, 0, 109, 0.05);
        border: 1px solid #f0e6ed;
        transition: all 0.3s ease;
        position: relative;}

.cenik-wrapper .package-card:hover {transform: translateY(-10px);
        border-color: var(--brand-color);
        box-shadow: 0 15px 45px rgba(160, 0, 109, 0.1);}

.cenik-wrapper .package-card.featured {border: 2px solid var(--brand-color);}

.cenik-wrapper .badge {position: absolute;
        top: -15px;
        left: 50%;
        transform: translateX(-50%);
        background: var(--brand-color);
        color: white;
        padding: 5px 20px;
        border-radius: 20px;
        font-size: 0.8rem;
        font-family: "Poppins", sans-serif;
        text-transform: uppercase;}

.cenik-wrapper .package-card h3 {font-size: 2.2rem; margin: 0;}

.cenik-wrapper .price-tag {font-size: 2rem;
        font-weight: 600;
        color: var(--text-main);
        margin: 20px 0;}

.cenik-wrapper .price-tag span {font-size: 1rem; color: #888; font-weight: 300;}

.cenik-wrapper .features {list-style: none;
        padding: 0;
        margin: 20px 0 30px;
        text-align: left;}

.cenik-wrapper .features li {margin-bottom: 12px;
        padding-left: 25px;
        position: relative;
        font-size: 0.95rem;}

.cenik-wrapper .features li::before {content: "✓";
        position: absolute;
        left: 0;
        color: var(--accent-color);
        font-weight: bold;}

.cenik-wrapper .table-section {background: var(--white);
        padding: 40px;
        border-radius: 15px;
        box-shadow: 0 5px 20px rgba(0,0,0,0.02);
        margin-bottom: 60px;}

.cenik-wrapper .table-section h3 {font-size: 2.5rem; text-align: center; margin-bottom: 30px;}

.cenik-wrapper table {width: 100%; border-collapse: collapse;}

.cenik-wrapper th {text-align: left;
        background: #fff5fb;
        padding: 15px;
        color: var(--brand-color);
        font-size: 0.9rem;
        text-transform: uppercase;}

.cenik-wrapper td {padding: 15px; border-bottom: 1px solid #f9f0f6;}

.cenik-wrapper .payroll-box {background: var(--brand-color);
        color: white;
        padding: 30px;
        border-radius: 12px;
        display: flex;
        justify-content: space-between;
        align-items: center;
        margin-top: 40px;}

.cenik-wrapper .payroll-box h4 {color: var(--white); font-size: 2rem; margin: 0;}

.cenik-wrapper .payroll-price {font-size: 1.6rem; font-weight: 600; color: var(--accent-color); text-align: right;}

.cenik-wrapper .faq-section {margin-top: 60px;
        padding: 20px;}

.cenik-wrapper .faq-section h3 {text-align: center; font-size: 2.5rem; margin-bottom: 40px;}

.cenik-wrapper .faq-grid {display: grid; grid-template-columns: 1fr 1fr; gap: 40px;}

.cenik-wrapper .faq-item h4 {font-size: 1.6rem; margin-bottom: 10px; line-height: 1.2;}

.cenik-wrapper .faq-item p {font-size: 0.95rem; color: #555; margin-left: 5px;}

.cenik-wrapper .cta-area {text-align: center; margin: 50px 0;}

.cenik-wrapper .btn {background: var(--brand-color);
        color: white;
        padding: 18px 45px;
        text-decoration: none;
        border-radius: 50px;
        font-weight: 600;
        transition: all 0.3s;
        display: inline-block;
        box-shadow: 0 5px 20px rgba(160, 0, 109, 0.2);}

.cenik-wrapper .btn:hover {background: #800057;
        transform: scale(1.05);}

@media (max-width: 768px) {
  .cenik-wrapper .package-grid, .cenik-wrapper .faq-grid {grid-template-columns: 1fr;}
  .cenik-wrapper .payroll-box {flex-direction: column; text-align: center; gap: 20px;}
  .cenik-wrapper .payroll-price {text-align: center;}
  .cenik-wrapper .header h2 {font-size: 2.2rem;}
}
