:root{
  --bg:#0b1220;
  --bg-2:#0f1a32;
  --card:#0f1930cc;
  --text:#e7ecff;
  --muted:#b9c3e6;
  --muted-2:#96a3d1;
  --line:#233058;
  --accent:#6ee7ff;
  --accent-2:#8b5cf6;
  --good:#4ade80;
  --warn:#fbbf24;
  --shadow: 0 18px 60px rgba(0,0,0,.35);
  --radius: 18px;
  --radius-2: 24px;
  --container: 1100px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,Helvetica,sans-serif;
  background: radial-gradient(1200px 700px at 25% -10%, rgba(110,231,255,.18), transparent 60%),
              radial-gradient(900px 500px at 85% 5%, rgba(139,92,246,.18), transparent 55%),
              linear-gradient(180deg, var(--bg), #070b14 65%);
  color:var(--text);
  line-height:1.55;
}

a{color:inherit; text-decoration:none}
img{max-width:100%; display:block}

.container{
  width:min(var(--container), calc(100% - 40px));
  margin-inline:auto;
}

.skip-link{
  position:absolute;
  left:-999px;
  top:12px;
  padding:10px 12px;
  background:#111b33;
  border:1px solid var(--line);
  border-radius:12px;
  z-index:999;
}
.skip-link:focus{left:12px}

/* Header */
.header{
  position:sticky;
  top:0;
  z-index:50;
  backdrop-filter: blur(10px);
  background: rgba(11,18,32,.65);
  border-bottom:1px solid rgba(35,48,88,.55);
}
.header__inner{display:flex; align-items:center; justify-content:space-between; padding:14px 0; gap:16px}
.brand{display:flex; align-items:center; gap:10px; font-weight:700}
.brand__mark{
  width:34px; height:34px; border-radius:12px;
  display:grid; place-items:center;
  background: linear-gradient(135deg, rgba(110,231,255,.26), rgba(139,92,246,.26));
  border:1px solid rgba(255,255,255,.12);
  box-shadow: 0 10px 30px rgba(0,0,0,.25);
}
.brand__text{letter-spacing:.2px}
.brand__accent{color:var(--accent)}

.nav{position:relative}
.nav__panel{display:flex; align-items:center; gap:18px}
.nav__link{color:var(--muted); font-weight:500; font-size:14px}
.nav__link:hover{color:var(--text)}

.nav__toggle{display:none; border:1px solid rgba(255,255,255,.14); background:rgba(15,26,50,.6); color:var(--text); border-radius:14px; padding:10px 12px; cursor:pointer}
.nav__toggle-lines{display:block; width:18px; height:12px; position:relative}
.nav__toggle-lines::before,.nav__toggle-lines::after,.nav__toggle-lines span{content:""; position:absolute; left:0; right:0; height:2px; background:rgba(231,236,255,.88); border-radius:2px}
.nav__toggle-lines::before{top:0}
.nav__toggle-lines::after{bottom:0}
.nav__toggle-lines span{top:5px}

/* Buttons */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  gap:10px;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(15,26,50,.55);
  color:var(--text);
  font-weight:600;
  font-size:14px;
  cursor:pointer;
  transition: transform .12s ease, background .2s ease, border-color .2s ease;
}
.btn:hover{transform: translateY(-1px); border-color: rgba(110,231,255,.28)}
.btn:active{transform: translateY(0)}
.btn--primary{
  background: linear-gradient(135deg, rgba(110,231,255,.25), rgba(139,92,246,.22));
  border-color: rgba(110,231,255,.35);
  box-shadow: 0 18px 50px rgba(110,231,255,.08);
}
.btn--ghost{background:transparent}
.btn--wide{width:100%}

.link{
  appearance:none;
  border:none;
  background:transparent;
  color:var(--muted);
  cursor:pointer;
  font-weight:600;
}
.link:hover{color:var(--text)}

/* Hero */
.hero{position:relative; padding:64px 0 32px}
.hero__grid{display:grid; grid-template-columns: 1.2fr .9fr; gap:34px; align-items:center}
.badge{
  display:inline-flex; gap:8px; align-items:center;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(15,26,50,.45);
  color:var(--muted);
  font-weight:600;
  font-size:13px;
}
.hero__title{font-size:42px; line-height:1.12; margin:14px 0 14px}
.hero__subtitle{color:var(--muted); margin:0 0 18px; max-width:60ch}
.accent{color:var(--accent)}
.hero__actions{display:flex; gap:12px; flex-wrap:wrap}
.hero__bullets{margin:18px 0 0; padding:0; list-style:none; color:var(--muted-2); display:grid; gap:10px}
.dot{width:8px; height:8px; border-radius:99px; background:rgba(110,231,255,.8); display:inline-block; margin-right:10px}

.hero__card{display:flex; justify-content:flex-end}
.hero-card{
  width:100%;
  border-radius: var(--radius-2);
  border:1px solid rgba(255,255,255,.12);
  background: linear-gradient(180deg, rgba(15,26,50,.6), rgba(15,26,50,.35));
  box-shadow: var(--shadow);
  overflow:hidden;
}
.hero-card__top{display:flex; align-items:center; justify-content:space-between; gap:10px; padding:14px 16px; border-bottom:1px solid rgba(255,255,255,.08)}
.hero-card__dots{display:flex; gap:6px}
.hero-card__dots span{width:8px; height:8px; border-radius:99px; background:rgba(231,236,255,.25)}
.hero-card__title{font-weight:700; font-size:14px}
.hero-card__pill{font-size:12px; font-weight:700; color: rgba(11,18,32,.95); background:rgba(110,231,255,.9); padding:6px 10px; border-radius:999px}
.hero-card__body{padding:16px}
.mini{display:grid; gap:10px; padding:12px; border-radius:16px; border:1px solid rgba(255,255,255,.10); background: rgba(7,11,20,.35)}
.mini__row{display:flex; justify-content:space-between; align-items:center; gap:12px}
.mini__chip{font-size:12px; color:var(--muted-2)}
.mini__value{font-weight:600; font-size:13px}
.hero-card__metrics{display:grid; grid-template-columns: repeat(auto-fit, minmax(290px, 1fr)); gap:10px; margin:12px 0 12px}
.metric{padding:10px; border-radius:16px; border:1px solid rgba(255,255,255,.10); background: rgba(7,11,20,.28)}
.metric__num{font-weight:800}
.metric__label{font-size:12px; color:var(--muted-2)}
.note{font-size:12px; color:var(--muted-2); margin:10px 0 0}
.note--slots{margin-top:10px; font-weight:800; font-size:14px; padding:10px 12px; border-radius:14px; border:1px solid rgba(255,255,255,.14); background: rgba(255,255,255,.06); color: rgba(255,255,255,.92)}

.hero__wave{
  position:absolute; left:0; right:0; bottom:-1px; height:74px;
  background: linear-gradient(180deg, transparent, rgba(7,11,20,1));
}

/* Strip */
.strip{padding:16px 0; border-top:1px solid rgba(255,255,255,.06); border-bottom:1px solid rgba(255,255,255,.06); background: rgba(7,11,20,.55)}
.strip__inner{display:flex; align-items:center; justify-content:space-between; gap:18px; flex-wrap:wrap}
.strip__text{margin:0; color:var(--muted); font-weight:600}
.strip__chips{display:flex; gap:10px; flex-wrap:wrap}
.chip{padding:8px 10px; border-radius:999px; border:1px solid rgba(255,255,255,.10); background: rgba(15,26,50,.40); color:var(--muted)}

/* Sections */
.section{padding:72px 0}
.section--alt{background: rgba(7,11,20,.35); border-top:1px solid rgba(255,255,255,.06); border-bottom:1px solid rgba(255,255,255,.06)}
.section__head{display:grid; gap:10px; margin-bottom:22px; max-width:75ch}
.section__head h2{margin:0; font-size:28px; line-height:1.2}
.section__head p{margin:0; color:var(--muted)}

.grid{display:grid; gap:16px}
.grid--3{grid-template-columns: repeat(3, 1fr)}
.grid--2{grid-template-columns: repeat(2, 1fr)}

.card{
  border-radius: var(--radius);
  border:1px solid rgba(255,255,255,.10);
  background: rgba(15,26,50,.35);
  padding:18px;
  box-shadow: 0 14px 40px rgba(0,0,0,.2);
}
.card__icon{font-size:22px}
.card h3{margin:10px 0 8px; font-size:16px}
.card p{margin:0; color:var(--muted)}

.panel{
  border-radius: var(--radius-2);
  border:1px solid rgba(255,255,255,.10);
  background: rgba(15,26,50,.30);
  padding:20px;
}
.panel h3{margin:0 0 10px}

.list{margin:0; padding-left:18px; color:var(--muted)}
.list li{margin:8px 0}

/* Steps */
.steps{margin:0; padding:0; list-style:none; display:grid; gap:12px}
.step{display:grid; grid-template-columns: 42px 1fr; gap:14px; padding:16px; border-radius: var(--radius-2); border:1px solid rgba(255,255,255,.10); background: rgba(15,26,50,.30)}
.step__num{width:42px; height:42px; border-radius:16px; display:grid; place-items:center; font-weight:800; background: rgba(110,231,255,.18); border:1px solid rgba(110,231,255,.25)}
.step__content h3{margin:0 0 6px}
.step__content p{margin:0; color:var(--muted)}

/* Pricing */
.pricing{display:grid; grid-template-columns: repeat(auto-fit, minmax(290px, 1fr)); gap:16px; align-items:stretch}
.price-card{
  position:relative;
  border-radius: var(--radius-2);
  border:1px solid rgba(255,255,255,.12);
  background: rgba(15,26,50,.33);
  padding:18px;
  box-shadow: var(--shadow);
}
.price-card--featured{
  background: linear-gradient(180deg, rgba(15,26,50,.48), rgba(15,26,50,.30));
  border-color: rgba(110,231,255,.22);
}
.ribbon{
  position:absolute;
  top:14px;
  right:14px;
  padding:8px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:800;
  color: rgba(11,18,32,.95);
  background: rgba(110,231,255,.95);
}
.price-card__head h3{margin:0 0 6px; font-size:18px}
.price-card__desc{margin:0; color:var(--muted)}
.price-card__price{display:flex; align-items:baseline; gap:8px; margin:14px 0 12px}
.price{font-size:42px; font-weight:900; letter-spacing:-.8px}
.currency{font-weight:800; color:var(--muted)}
.once{margin-left:auto; font-size:12px; color:var(--muted)}
.checklist{margin:0 0 16px; padding:0; list-style:none; display:grid; gap:10px; color:var(--muted)}
.checklist li{display:flex; gap:10px}
.checklist li::before{content:"✓"; color: rgba(74,222,128,.95); font-weight:900}
.stack{display:grid; gap:10px}
.fineprint{margin:16px 0 0; color:var(--muted-2); font-size:12px}

/* Quotes */
.quote{
  margin:0;
  border-radius: var(--radius-2);
  border:1px solid rgba(255,255,255,.10);
  background: rgba(15,26,50,.28);
  padding:18px;
}
.quote blockquote{margin:0; color:var(--text); font-weight:600}
.quote figcaption{margin-top:12px; color:var(--muted-2); font-size:13px}

/* Accordion */
.accordion{display:grid; gap:10px}
.acc{border-radius: var(--radius-2); border:1px solid rgba(255,255,255,.10); background: rgba(15,26,50,.28); padding:12px 14px}
.acc summary{cursor:pointer; font-weight:700}
.acc__body{margin-top:10px; color:var(--muted)}

/* Contact */
.contact{display:grid; grid-template-columns: 1.05fr .95fr; gap:18px; align-items:start}
.contact__cards{display:grid; grid-template-columns: repeat(auto-fit, minmax(290px, 1fr)); gap:10px; margin-top:16px}
.mini-card{padding:12px; border-radius:16px; border:1px solid rgba(255,255,255,.10); background: rgba(15,26,50,.28)}
.mini-card__label{font-size:12px; color:var(--muted-2)}
.mini-card__value{font-weight:800}

.form{border-radius: var(--radius-2); border:1px solid rgba(255,255,255,.12); background: rgba(15,26,50,.33); padding:16px}
.form__row{display:grid; grid-template-columns: 1fr 1fr; gap:10px}
.field{display:grid; gap:8px; margin-bottom:10px}
.field span{font-size:13px; color:var(--muted); font-weight:600}
input, select, textarea{
  width:100%;
  border-radius: 14px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(7,11,20,.35);
  color:var(--text);
  padding:12px 12px;
  outline:none;
}
textarea{resize:vertical}
input:focus, select:focus, textarea:focus{border-color: rgba(110,231,255,.35); box-shadow: 0 0 0 4px rgba(110,231,255,.08)}
.checkbox{display:flex; gap:10px; align-items:flex-start; color:var(--muted); font-size:13px; margin:12px 0}
.checkbox input{width:18px; height:18px; margin-top:2px}
.form__hint{margin:10px 0 0; color:var(--muted-2); font-size:12px}
.form__status{margin:10px 0 0; font-weight:700}

/* CTA */
.cta{padding:48px 0; background: linear-gradient(135deg, rgba(110,231,255,.18), rgba(139,92,246,.14)); border-top:1px solid rgba(255,255,255,.08)}
.cta__inner{display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap}
.cta h2{margin:0; font-size:24px}
.cta p{margin:8px 0 0; color:var(--muted)}
.cta__actions{display:flex; gap:10px; flex-wrap:wrap}

/* Footer */
.footer{padding:40px 0 22px; background: rgba(7,11,20,.65); border-top:1px solid rgba(255,255,255,.06)}
.footer__grid{display:grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap:18px}
.brand--footer{margin-bottom:10px}
.footer h3{margin:0 0 10px; font-size:14px; color:var(--text)}
.footer p{margin:0; color:var(--muted)}
.footer__links{margin:0; padding:0; list-style:none; display:grid; gap:8px; color:var(--muted)}
.footer__links a:hover{color:var(--text)}
.footer__bottom{display:flex; justify-content:space-between; gap:12px; margin-top:18px; padding-top:18px; border-top:1px solid rgba(255,255,255,.06); color:var(--muted-2); font-size:13px; flex-wrap:wrap}

/* Modals */
.modal{position:fixed; inset:0; display:grid; place-items:center; z-index:70}
.modal[hidden]{display:none}
.modal__backdrop{position:absolute; inset:0; background: rgba(0,0,0,.55)}
.modal__panel{
  position:relative;
  width:min(620px, calc(100% - 30px));
  border-radius: var(--radius-2);
  border:1px solid rgba(255,255,255,.12);
  background: rgba(15,26,50,.78);
  backdrop-filter: blur(10px);
  box-shadow: var(--shadow);
  max-height: calc(100vh - 24px);
  overflow:auto;
  -webkit-overflow-scrolling: touch;
}
.modal__head{display:flex; justify-content:space-between; align-items:flex-start; gap:12px; padding:14px 16px; border-bottom:1px solid rgba(255,255,255,.08)}
.modal__kicker{font-size:12px; color:var(--muted-2); font-weight:700}
.modal__title{margin:2px 0 0}
.icon-btn{
  border-radius: 14px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(7,11,20,.35);
  color:var(--text);
  width:42px; height:42px;
  cursor:pointer;
}
.modal__form{padding:16px}
.modal__hint{margin:10px 0 0; color:var(--muted-2); font-size:12px}

/* Cookie */
.cookie{padding:16px}
.cookie p{margin:0 0 14px; color:var(--muted)}
.cookie__opts{display:grid; gap:10px; margin:14px 0}
.toggle{display:flex; gap:12px; align-items:flex-start; padding:12px; border-radius:16px; border:1px solid rgba(255,255,255,.10); background: rgba(7,11,20,.30)}
.toggle input{width:18px; height:18px; margin-top:2px}
.toggle strong{display:block}
.toggle em{display:block; font-style:normal; color:var(--muted-2); font-size:12px}
.cookie__actions{display:flex; gap:10px; justify-content:flex-end; flex-wrap:wrap}
.cookie__small{margin-top:12px; color:var(--muted-2); font-size:12px}

/* Responsive */
@media (max-width: 980px){
  .hero__grid{grid-template-columns: 1fr;}
  .hero__card{justify-content:flex-start}
  .grid--3{grid-template-columns: 1fr 1fr}
  .pricing{grid-template-columns: 1fr}
  .contact{grid-template-columns: 1fr}
  .contact__cards{grid-template-columns: 1fr}
  .footer__grid{grid-template-columns: 1fr 1fr}
}
@media (max-width: 720px){
  .hero__title{font-size:34px}
  .grid--3{grid-template-columns: 1fr}
  .grid--2{grid-template-columns: 1fr}
  .form__row{grid-template-columns: 1fr}

  .nav__toggle{display:inline-flex}
  .nav__panel{
    position:absolute;
    right:0;
    top:52px;
    width:min(320px, calc(100vw - 40px));
    padding:12px;
    border-radius: 18px;
    border:1px solid rgba(255,255,255,.12);
    background: rgba(15,26,50,.92);
    box-shadow: var(--shadow);
    display:none;
    flex-direction:column;
    align-items:stretch;
  }
  .nav__panel.is-open{display:flex}
  .nav__link{padding:10px 8px}
  .nav__cta{width:100%}
}

.price-row{display:flex;align-items:baseline;gap:.35rem}
.old-price{margin-top:.25rem;opacity:.8}
.old-price .old{text-decoration:line-through;text-decoration-thickness:2px;opacity:.9;font-weight:600}
.price--promo{letter-spacing:-0.02em}
.subnote{display:block;margin-top:.35rem;color:var(--muted);font-size:.95rem}

.notice{
  margin-top:1.2rem;
  display:flex;
  gap:1rem;
  padding:1rem 1.1rem;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(255,255,255,.04);
  border-radius:16px;
}
.notice__icon{font-size:1.25rem;line-height:1}
.notice__content p{margin:.15rem 0}
.notice__small{color:var(--muted);font-size:.95rem}






/* --- Demo rezerwacji (flatpickr) --- */

/* Bigger calendar popup */
.flatpickr-calendar{
  width: 380px !important;
  font-size: 15px;
  border-radius: 18px;
  overflow: hidden;
}
.flatpickr-rContainer,
.flatpickr-days,
.dayContainer{
  width: 380px !important;
  min-width: 380px !important;
  max-width: 380px !important;
}
.flatpickr-weekdays{ height: 38px; }
/* Wymuś układ 7 dni w rzędzie (niezależnie od stylów CDN) */
.flatpickr-weekdays .flatpickr-weekdaycontainer{
  display: grid !important;
  grid-template-columns: repeat(7, 1fr) !important;
}
.dayContainer{
  display: grid !important;
  grid-template-columns: repeat(7, 1fr) !important;
}
.dayContainer .flatpickr-day{
  width: 100% !important;
  max-width: none !important;
}

span.flatpickr-weekday{ line-height: 38px; font-weight: 700; font-size: 12px; }
.flatpickr-day{
  height: 46px;
  line-height: 46px;
  border-radius: 12px;
}
.flatpickr-current-month{ font-size: 18px; padding: 10px 0; }
.flatpickr-months .flatpickr-prev-month,
.flatpickr-months .flatpickr-next-month{ top: 10px; }
.flatpickr-day{ position: relative; }
.flatpickr-day .fp-slots{
  position: absolute;
  right: 6px;
  bottom: 6px;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  border-radius: 999px;
  font-size: 11px;
  line-height: 18px;
  font-weight: 700;
  letter-spacing: .2px;
  background: rgba(0,0,0,.08);
  color: rgba(0,0,0,.75);
  pointer-events: none;
}
.flatpickr-day.selected .fp-slots,
.flatpickr-day.today .fp-slots{
  background: rgba(0,0,0,.16);
  color: rgba(0,0,0,.85);
}
.flatpickr-day .fp-slots.is-zero{ opacity: .45; }


/* Ukryj stare odznaki z liczbą (zostawione w JS dla kompatybilności) */
.flatpickr-day .fp-slots{ display:none !important; }

/* Pasek dostępności w komórce dnia */
.flatpickr-day{
  position: relative;
}
.flatpickr-day .fp-availability{
  position: absolute;
  left: 7px;
  right: 7px;
  bottom: 3px;
  height: 6px;
  border-radius: 999px;
  background: rgba(0,0,0,.12);
  overflow: hidden;
  pointer-events: none;
}
.flatpickr-day .fp-availability__fill{
  display: block;
  height: 100%;
  width: 0%;
  border-radius: 999px;
  background: #16a34a; /* zielony = dużo terminów */
}

/* Kolor paska w zależności od dostępności */
.flatpickr-day.fp-low .fp-availability__fill{ background: #f59e0b; }   /* mało */
.flatpickr-day.fp-mid .fp-availability__fill{ background: #22c55e; }   /* średnio */
.flatpickr-day.fp-high .fp-availability__fill{ background: #16a34a; }  /* dużo */

/* Brak terminów: czerwony dzień */
.flatpickr-day.fp-none{
  color: #dc2626 !important;
}
.flatpickr-day.fp-none .fp-availability{
  background: rgba(220,38,38,.18);
}
.flatpickr-day.fp-none .fp-availability__fill{
  background: #dc2626;
}


/* (scoped legacy selectors kept below for safety) */



/* --- Walidacja formularza (PL) --- */
.field.is-error select,
.field.is-error input{
  border-color: rgba(220,38,38,.85) !important;
  box-shadow: 0 0 0 3px rgba(220,38,38,.18) !important;
}
.field__error{
  margin-top: 6px;
  font-size: 12px;
  color: #fca5a5;
}


/* === Mobile-friendly calendar (flatpickr inline) === */
.calendar-inline{ display:none; margin-top:10px; }
@media (max-width: 640px){
  .calendar-inline{ display:block; }
  /* keep input but reduce accidental keyboard; still focusable */
  input[data-date]{ caret-color: transparent; }
  .flatpickr-calendar{ width: 100% !important; max-width: 420px; }
}
/* Ensure calendar is always above modal overlays */
.flatpickr-calendar{ z-index: 10050 !important; }


/* Mobile: make modal scrollable and full-height */
@media (max-width: 640px){
  .modal{place-items:stretch;}
  .modal__panel{width:100%; height:100%; max-height:100vh; border-radius:0;}
  .modal__head{position:sticky; top:0; z-index:1; background: rgba(15,26,50,.92); backdrop-filter: blur(10px);}
}


/* Pricing: keep / mies. close to price */
.price-card__price{display:flex; align-items:baseline; gap:12px; flex-wrap:wrap}
.price-card__price .old-price{order:2; margin-left:0}
.price-card__price .once{order:3; margin-left:0; opacity:.9}


/* Dark dropdowns (select/option + flatpickr) */
select, option {
  background: rgba(11,18,32,.95);
  color: var(--text);
}
select:focus {
  outline: 2px solid rgba(139, 168, 255, .35);
  outline-offset: 2px;
}
/* Flatpickr */
.flatpickr-calendar, .flatpickr-innerContainer, .flatpickr-rContainer,
.flatpickr-days, .flatpickr-weekdays, .flatpickr-months {
  background: rgba(11,18,32,.95) !important;
  color: var(--text) !important;
}
.flatpickr-day, .flatpickr-weekday {
  color: var(--text) !important;
}
.flatpickr-day:hover {
  background: rgba(139,168,255,.18) !important;
}


.brand__mark svg{display:block}


/* Flatpickr month/year visibility */
.flatpickr-current-month, 
.flatpickr-current-month .cur-month,
.flatpickr-current-month input.cur-year,
.flatpickr-monthDropdown-months,
.flatpickr-monthDropdown-months option {
  color: var(--text) !important;
  background: rgba(11,18,32,.95) !important;
}
.numInputWrapper span.arrowUp:after, .numInputWrapper span.arrowDown:after {
  border-bottom-color: var(--text) !important;
  border-top-color: var(--text) !important;
}


/* Form field errors */
.field.is-error input, .field.is-error select, .field.is-error textarea {
  border-color: rgba(255, 95, 95, .6) !important;
}
.field__error{
  display:block;
  margin-top:6px;
  font-size:.85rem;
  color: rgba(255, 120, 120, .95);
}

/* Calendar availability bars */
.lw-bars{
  position:absolute;
  left:6px;
  right:6px;
  bottom:4px;
  display:flex;
  gap:3px;
  justify-content:center;
  pointer-events:none;
}
.lw-bar{
  height:3px;
  flex:1;
  border-radius:999px;
  background: rgba(255,255,255,.14);
}
.lw-bar.is-on{
  background: rgba(70, 210, 130, .9);
}
.flatpickr-day.lw-day--full{
  color: rgba(255, 120, 120, .95) !important;
}
.flatpickr-day.lw-day--full:hover{
  background: rgba(255, 80, 80, .18) !important;
}

/* Past days (disabled) */
.flatpickr-day.flatpickr-disabled, .flatpickr-day.prevMonthDay.flatpickr-disabled {
  color: rgba(255,255,255,.35) !important;
}


/* Hide availability bars on disabled/past days */
.flatpickr-day.flatpickr-disabled .lw-bars{display:none !important}
