:root{
  --beige-bg:#f5eee6;
  --beige-card:#f8f2ea;
  --gold:#d8a74b;
  --gold-soft:#f2c879;
  --brown-dark:#4a3224;
  --brown-soft:#7a5941;
  --border-soft:rgba(122, 89, 65, 0.25);
  --text-main:#3b2a20;
  --text-muted:#7e6a5b;

  --radius-lg:18px;
  --radius-md:14px;
  --radius-pill:999px;
  --shadow-soft:0 14px 35px rgba(60,38,22,0.15);
  --t:0.16s ease-out;

  --font: system-ui,-apple-system,BlinkMacSystemFont,"SF Pro","Inter",sans-serif;
}

*{ box-sizing:border-box; }

body.page-beige{
  margin:0;
  font-family:var(--font);
  background:
    radial-gradient(circle at top left, rgba(216,167,75,0.12), transparent 55%),
    radial-gradient(circle at bottom right, rgba(122,89,65,0.10), transparent 60%),
    var(--beige-bg);
  color:var(--text-main);
  min-height:100vh;
  display:flex;
  justify-content:center;
  padding:50px 20px;
}

.booking-shell{ width:100%; max-width:1040px; }
.booking-header{ margin-bottom:18px; }
.booking-header h1{
  margin:0 0 8px;
  font-size:2.05rem;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--brown-dark);
}
.booking-header p{ margin:0; color:var(--text-muted); }

.booking-flow{
  margin-top:16px;
  background: linear-gradient(135deg, rgba(255,255,255,0.92), rgba(248,242,234,0.96));
  border-radius:24px;
  padding:40px 32px 40px;
  box-shadow:var(--shadow-soft);
  border:1px solid rgba(255,255,255,0.8);
}

/* Hide inputs safely (vrátane kategórií!) */
.svc-input,.emp-input,.date-input,.time-input,.cat-input{
  position:absolute;
  opacity:0;
  pointer-events:none;
  width:1px;height:1px;
}

.section{
  padding:16px 0;
  border-bottom:1px solid rgba(139,109,86,0.15);
}
.section:last-of-type{ border-bottom:none; padding-bottom:0; }

.section-title{
  font-size:1.02rem;
  text-transform:uppercase;
  letter-spacing:0.12em;
  color:var(--brown-soft);
  margin:0 0 12px;
}

/* ===== CATEGORY TABS (z môjho HTML) ===== */
.category-tabs{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-bottom:14px;
}

.category-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border-radius: var(--radius-pill);
  background: rgba(248,242,234,0.72);
  border:1px solid rgba(122,89,65,0.22);
  color: var(--brown-dark);
  cursor:pointer;
  font-weight:650;
  letter-spacing:0.02em;
  transition: transform var(--t), box-shadow var(--t), border var(--t), background var(--t);
  user-select:none;
}

.category-pill:hover{
  transform: translateY(-1px);
  border-color: rgba(216,167,75,0.70);
  box-shadow: 0 10px 22px rgba(139,109,86,0.18);
}

/* Active pill via checked category input */
#cat-licenie:checked   ~ .section-categories .category-tabs label[for="cat-licenie"],
#cat-osetrenia:checked ~ .section-categories .category-tabs label[for="cat-osetrenia"],
#cat-depilacia:checked ~ .section-categories .category-tabs label[for="cat-depilacia"],
#cat-ine:checked       ~ .section-categories .category-tabs label[for="cat-ine"]{
  background: linear-gradient(135deg, #e6c27a, #d8a74b);
  border-color: rgba(216,167,75, 1);
  color:#2f1f14;
  box-shadow: 0 12px 28px rgba(60,38,22,0.18);
}

/* ===== SERVICES GROUPS (prepínanie kategórií) ===== */
.services-wrapper{ margin-top:6px; }

.services-group{ display:none; }
#cat-licenie:checked   ~ .section-categories .services-group--licenie{ display:block; }
#cat-osetrenia:checked ~ .section-categories .services-group--osetrenia{ display:block; }
#cat-depilacia:checked ~ .section-categories .services-group--depilacia{ display:block; }
#cat-ine:checked       ~ .section-categories .services-group--ine{ display:block; }

/* ===== SERVICES GRID & CARD (z môjho HTML) ===== */
.services-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap:10px;
}

.service-card{
  display:block;
  padding:12px 14px;
  border-radius: var(--radius-lg);
  background: var(--beige-card);
  border:1px solid var(--border-soft);
  cursor:pointer;
  transition: transform var(--t), box-shadow var(--t), border var(--t), background var(--t);
}

.service-card:hover{
  transform: translateY(-1px);
  box-shadow: 0 10px 22px rgba(139,109,86,0.18);
  border-color: rgba(216,167,75,0.80);
}

.service-title{
  font-size:0.95rem;
  line-height:1.18;
  font-weight:700;
  color: var(--brown-dark);
}

.service-meta{
  margin-top:6px;
  font-size:0.84rem;
  color: var(--text-muted);
  font-weight:600;
}

/* Checked highlight – modern browsers */
label.service-card:has(input:checked){
  background: linear-gradient(135deg, #e6c27a, #d8a74b);
  border-color: rgba(216,167,75,1);
  box-shadow: 0 12px 28px rgba(60,38,22,0.22);
  transform: translateY(-1px);
}
label.service-card:has(input:checked) .service-title,
label.service-card:has(input:checked) .service-meta{
  color:#2f1f14;
}

/* Fallback for browsers without :has()
   (neurobí “selected” styling, ale aspoň nebude nič plain text) */
@supports not selector(label:has(input:checked)){
  .service-card input:checked + .service-title{ font-weight:800; }
}

/* ===== Employees (z môjho HTML) ===== */
.section-employees{ display:none; }
.section-categories:has(input[name="services"]:checked) ~ .section-employees{ display:block; }

.employees-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap:10px;
  margin-top:6px;
}

.employee-card{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-radius: var(--radius-lg);
  background:#f7ede1;
  border:1px solid var(--border-soft);
  cursor:pointer;
  transition: background var(--t), border var(--t), box-shadow var(--t), transform var(--t);
}

.employee-avatar{
  width:34px;height:34px;
  border-radius:50%;
  background: linear-gradient(135deg, #d8a74b, #f2c879);
  display:flex;align-items:center;justify-content:center;
  color:#3b2415;
  font-weight:800;
}

.employee-name{ font-size:0.95rem; font-weight:750; color:var(--brown-dark); }
.employee-meta{ font-size:0.78rem; color:var(--text-muted); }

.employee-card:hover{
  transform: translateY(-1px);
  box-shadow: 0 10px 22px rgba(139,109,86,0.15);
  border-color: rgba(216,167,75,0.8);
}

.employee-card:has(input:checked){
  background: linear-gradient(135deg, #e6c27a, #d8a74b);
  border-color: rgba(216,167,75,1);
  box-shadow: 0 12px 28px rgba(60,38,22,0.22);
  transform: translateY(-1px);
}

/* ===== Calendar & Times (z môjho HTML) ===== */
.section-calendar{ display:none; }
.section-employees:has(input[name="employee"]:checked) ~ .section-calendar{ display:block; }

.calendar-grid{
  display:grid;
  grid-template-columns: repeat(7, minmax(0,1fr));
  gap:8px;
  margin-top:8px;
}

/* (ak tvoj JS pridáva buttony/divy, aspoň základ) */
.calendar-grid .day,
.calendar-grid button{
  border-radius: 14px;
  border: 1px solid rgba(122,89,65,0.25);
  background: rgba(255,255,255,0.55);
  padding: 10px 8px;
  cursor:pointer;
  transition: transform var(--t), box-shadow var(--t), border var(--t), 
}
.calendar-grid .day:hover,
.calendar-grid button:hover{
  transform: translateY(-1px);
  border-color: rgba(216,167,75,0.70);
  box-shadow: 0 10px 22px rgba(139,109,86,0.18);
}


.times-grid .time,
.times-grid button{
  border-radius: var(--radius-pill);
  border: 1px solid rgba(122,89,65,0.25);
  background: rgba(255,255,255,0.55);
  padding: 10px 12px;
  cursor:pointer;
  font-weight:650;
  color: var(--brown-dark);
  transition: transform var(--t), box-shadow var(--t), border var(--t), background var(--t);
}
.times-grid .time:hover,
.times-grid button:hover{
  transform: translateY(-1px);
  border-color: rgba(216,167,75,0.70);
  box-shadow: 0 10px 22px rgba(139,109,86,0.18);
}
.times-hint{
  margin-top:6px;
  font-size:0.8rem;
  color: var(--text-muted);
}

/* ===== Contact ===== */
.contact-layout{
  display:grid;
  grid-template-columns: minmax(0,1.1fr) minmax(0,1.2fr);
  gap:18px;
  margin-top:8px;
}

.summary-card{
  background: var(--beige-card);
  border-radius: 18px;
  border: 1px solid var(--border-soft);
  padding: 14px 16px;
}
.summary-card h3{ margin: 0 0 10px; color: var(--brown-dark); }
.summary-line{
  display:flex;
  justify-content:space-between;
  font-size:0.86rem;
  margin:3px 0;
}
.summary-line span:first-child{ color:var(--text-muted); }

.contact-form{
  background:#f9f2e9;
  border-radius: 18px;
  border:1px solid rgba(139,109,86,0.2);
  padding: 14px 16px;
}

.field{
  display:flex;
  flex-direction:column;
  gap:4px;
  margin-bottom:10px;
  font-size:0.9rem;
}
.field label{ color:var(--brown-soft); }

.field input,.field textarea{
  border-radius:12px;
  border:1px solid rgba(139,109,86,0.35);
  padding:9px 11px;
  font:inherit;
  color:var(--text-main);
  background:#fcf7f1;
  outline:none;
}
.field textarea{ min-height: 90px; resize: vertical; }

.btn-primary{
  padding:10px 18px;
  border-radius: var(--radius-pill);
  border:none;
  background: linear-gradient(135deg, #d8a74b, #f2c879);
  color:#3b2415;
  font-size:0.9rem;
  letter-spacing:0.10em;
  text-transform:uppercase;
  font-weight:750;
  cursor:pointer;
  transition: transform var(--t), box-shadow var(--t), filter var(--t), opacity var(--t);
}
.btn-primary:hover{
  transform: translateY(-1px);
  box-shadow: 0 10px 24px rgba(139,109,86,0.28);
  filter: brightness(1.03);
}
.btn-primary:disabled{
  opacity: 0.55;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
  filter: none;
}

/* ===== Modal (z môjho HTML) ===== */
.modal-backdrop{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.35);
  display:none;
  align-items:center;
  justify-content:center;
  padding: 18px;
}
.modal-backdrop.is-open{ display:flex; }

.modal{
  width: min(520px, 100%);
  background: #fff;
  border-radius: 18px;
  border: 1px solid rgba(0,0,0,0.08);
  box-shadow: 0 18px 45px rgba(0,0,0,0.22);
  padding: 16px 16px 14px;
}
.modal-title{ margin:0 0 6px; color: var(--brown-dark); }
.modal-text{ margin:0 0 12px; color: var(--text-muted); }
.modal-actions{
  display:flex;
  justify-content:flex-end;
  gap:10px;
  margin-top: 12px;
}
.btn-secondary{
  padding:10px 14px;
  border-radius: var(--radius-pill);
  border:1px solid rgba(122,89,65,0.25);
  background: rgba(255,255,255,0.65);
  color: var(--brown-dark);
  text-decoration:none;
  font-weight:700;
}

/* ===== Responsive ===== */
@media (max-width: 980px){
  .services-grid{ grid-template-columns: repeat(2, minmax(0,1fr)); }
  .calendar-grid{ grid-template-columns: repeat(4, minmax(0,1fr)); }
  .contact-layout{ grid-template-columns: 1fr; }
}
@media (max-width: 720px){
  body.page-beige{ padding: 20px 10px; }
  .booking-flow{ padding: 16px 14px; border-radius: 18px; }
  .services-grid{ grid-template-columns: 1fr !important; }
  .employees-grid{ grid-template-columns: 1fr !important; }
  .calendar-grid{ grid-template-columns: repeat(3, minmax(0,1fr)) !important; }
}

/* ===== Split columns inside a category ===== */
.services-split{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap:12px;
  margin-top:6px;
}

.services-col{
  background: rgba(255,255,255,0.45);
  border:1px solid rgba(122,89,65,0.18);
  border-radius:18px;
  padding:12px;
}

.services-col-title{
  margin:0 0 10px;
  font-size:0.95rem;
  font-weight:800;
  color:var(--brown-dark);
  letter-spacing:0.02em;
}

/* Full-width block under the two cols */
.services-col--full{
  margin-top:12px;
}

.services-col--full{
  grid-column: 1 / -1;
}

/* keep your existing .services-grid rules */
@media (max-width: 980px){
  .services-split{ grid-template-columns: 1fr; }
}
/* ===== Fix "osamelá posledná karta" v 3-stĺpcovom gride ===== */
@media (min-width: 981px){
  .services-grid{
    grid-template-columns: repeat(3, minmax(0,1fr));
  }

  /* ak je posledná karta sama v novom riadku, roztiahni ju cez 2 stĺpce a vycentruj */
  .services-grid > .service-card:last-child:nth-child(3n+1){
    grid-column: 1 / span 3;        /* začne v strede (stĺpec 2) a zaberie 2 stĺpce */
    max-width: 100%;
  }
}

/* ===== Fix osamelá posledná karta v 3-stĺpcovom gride (všetky kategórie) ===== */
@media (min-width: 981px){
  .services-grid{
    grid-template-columns: repeat(3, minmax(0,1fr));
  }

  /* posledná karta sama v riadku → širšia a vycentrovaná */
  .services-grid > .service-card:last-child:nth-child(3n+1){
    grid-column: 1 / span 3;
  }
}

/* split layout cols (ak ho ešte nemáš) */
.services-split{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap:12px;
  margin-top:6px;
}
.services-col{
  background: rgba(255,255,255,0.45);
  border:1px solid rgba(122,89,65,0.18);
  border-radius:18px;
  padding:12px;
}
.services-col-title{
  margin:0 0 10px;
  font-size:0.95rem;
  font-weight:800;
  color:var(--brown-dark);
  letter-spacing:0.02em;
}
.services-col--full{ grid-column: 1 / -1; margin-top:12px; }

@media (max-width: 980px){
  .services-split{ grid-template-columns: 1fr; }
}

.service-desc{
  margin-top:6px;
  font-size:0.79rem;     /* bolo ~0.86 */
  line-height:1.25;
  color:var(--text-muted);
}
.service-title{
  font-size:1.01rem;   /* bolo ~0.95 */
  line-height:1.18;
  font-weight:750;
}

/* ===== EMPLOYEE selection fix (inputs sú mimo labelov) ===== */

.employee-card{
  display:flex;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-radius: var(--radius-lg);
  background:#f7ede1;
  border:1px solid var(--border-soft);
  cursor:pointer;
  transition: background var(--t), border var(--t), box-shadow var(--t), transform var(--t);
}

.employee-card:hover{
  transform: translateY(-1px);
  box-shadow: 0 10px 22px rgba(139,109,86,0.15);
  border-color: rgba(216,167,75,0.8);
}

/* ACTIVE state podľa checked inputu (správny spôsob pre label[for]) */
#emp-sona:checked ~ .section-employees .employees-grid label[for="emp-sona"],
#emp-mira:checked ~ .section-employees .employees-grid label[for="emp-mira"],
#emp-any:checked  ~ .section-employees .employees-grid label[for="emp-any"]{
  background: linear-gradient(135deg, #e6c27a, #d8a74b);
  border-color: rgba(216,167,75,1);
  box-shadow: 0 12px 28px rgba(60,38,22,0.22);
  transform: translateY(-1px);
}

#emp-sona:checked ~ .section-employees .employees-grid label[for="emp-sona"] .employee-name,
#emp-mira:checked ~ .section-employees .employees-grid label[for="emp-mira"] .employee-name,
#emp-any:checked  ~ .section-employees .employees-grid label[for="emp-any"] .employee-name{
  color:#2f1f14;
  font-weight:800;
}

#emp-sona:checked ~ .section-employees .employees-grid label[for="emp-sona"] .employee-meta,
#emp-mira:checked ~ .section-employees .employees-grid label[for="emp-mira"] .employee-meta,
#emp-any:checked  ~ .section-employees .employees-grid label[for="emp-any"] .employee-meta{
  color:#2f1f14;
  opacity:0.85;
}

#emp-sona:checked ~ .section-employees .employees-grid label[for="emp-sona"] .employee-avatar,
#emp-mira:checked ~ .section-employees .employees-grid label[for="emp-mira"] .employee-avatar,
#emp-any:checked  ~ .section-employees .employees-grid label[for="emp-any"] .employee-avatar{
  background: rgba(255,255,255,0.35);
  border: 1px solid rgba(47,31,20,0.25);
}

/* kalendár sa zobrazí po výbere kozmetičky */
.section-calendar{ display:none; }
#emp-sona:checked ~ .section-calendar,
#emp-mira:checked ~ .section-calendar,
#emp-any:checked  ~ .section-calendar{
  display:block;
}

/* ===== Calendar: nech to nie je plain text ===== */
#calendar-grid{
  display:grid;
  grid-template-columns: repeat(7, minmax(0,1fr));
  gap:8px;
  margin-top:8px;
}

/* štýl pre čokoľvek čo JS vloží (button, a, div) */
#calendar-grid > *{
  border-radius: 14px;
  border: 1px solid rgba(122,89,65,0.25);
  background: rgba(255,255,255,0.55);
  padding: 10px 8px;
  cursor:pointer;
  transition: transform var(--t), box-shadow var(--t), border var(--t), background var(--t), opacity var(--t);
  text-align:center;
  font-weight:700;
  color: var(--brown-dark);
  user-select:none;
}

/* hover */
#calendar-grid > *:hover{
  transform: translateY(-1px);
  border-color: rgba(216,167,75,0.70);
  box-shadow: 0 10px 22px rgba(139,109,86,0.18);
  background: rgba(255,255,255,0.72);
}

/* disabled (ak JS dá disabled na button) */
#calendar-grid button:disabled{
  opacity:0.35;
  cursor:not-allowed;
  transform:none;
  box-shadow:none;
}

/* selected (ak JS používa class 'active' alebo 'selected') */
#calendar-grid .active,
#calendar-grid .selected{
  background: linear-gradient(135deg, #e6c27a, #d8a74b);
  border-color: rgba(216,167,75,1);
  box-shadow: 0 12px 28px rgba(60,38,22,0.18);
  color:#2f1f14;
}

/* ===== Times: nech to nie je plain text ===== */
.times-grid{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:8px;
}

/* opäť: chytí všetko (button/div/a) */
.times-grid > *{
  border-radius: var(--radius-pill);
  border: 1px solid rgba(122,89,65,0.25);
  background: rgba(255,255,255,0.55);
  padding: 10px 12px;
  cursor:pointer;
  font-weight:750;
  color: var(--brown-dark);
  transition: transform var(--t), box-shadow var(--t), border var(--t), background var(--t), opacity var(--t);
  user-select:none;
}

/* hover */
.times-grid > *:hover{
  transform: translateY(-1px);
  border-color: rgba(216,167,75,0.70);
  box-shadow: 0 10px 22px rgba(139,109,86,0.18);
  background: rgba(255,255,255,0.72);
}

/* selected (ak JS dá class active/selected) */
.times-grid .active,
.times-grid .selected{
  background: linear-gradient(135deg, #e6c27a, #d8a74b);
  border-color: rgba(216,167,75,1);
  box-shadow: 0 12px 28px rgba(60,38,22,0.18);
  color:#2f1f14;
}

/* disabled times */
.times-grid button:disabled{
  opacity:0.35;
  cursor:not-allowed;
  transform:none;
  box-shadow:none;
}

/* responsive kalendár */
@media (max-width: 980px){
  #calendar-grid{ grid-template-columns: repeat(4, minmax(0,1fr)); }
}
@media (max-width: 720px){
  #calendar-grid{ grid-template-columns: repeat(3, minmax(0,1fr)); }
  .times-grid > *{ width: 100%; text-align:center; }
}
/* text dole */
.booking-disabled {
  margin-top: 25px;
  text-align: center;
  font-size: 1rem;
  color: var(--text-muted);
  padding: 15px;
  border-top: 1px solid rgba(122,89,65,0.2);
}