:root{
  --bg:#0d2f3c; --panel:#0a2631; --ink:#e8f6ff; --mut:#97c1cf; --line:#1a4453;
  --pill:#0f3949; --pill-ink:#cfeaf7; --pill-sel:#ffc24b; --accent:#f2a83b;
}

.wf-bkg-widget{font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial;color:var(--ink);background:var(--bg);border-radius:10px;padding:14px;max-width:1100px;margin-inline:auto;box-shadow:0 2px 10px rgba(0,0,0,.18);font-size:14px;line-height:1.35}
@media (min-width:960px){.wf-bkg-widget{display:grid;grid-template-columns:300px 1fr;gap:14px}}
.wf-bkg-widget *{color:inherit}

/* Kalendář */
.wf-bkg-cal{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:8px}
.wf-bkg-cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.wf-bkg-month{font-weight:600;letter-spacing:.5px;color:var(--mut);font-size:13px}
.wf-bkg-prev,.wf-bkg-next{background:transparent;border:1px solid var(--line);color:var(--ink);border-radius:7px;padding:3px 8px;cursor:pointer;font-size:12px}
.wf-bkg-grid-head,.wf-bkg-grid-body{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.wf-bkg-grid-head span{font-size:11px;opacity:.75;text-align:center;color:var(--mut)}
.wf-bkg-day{height:30px;display:flex;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:7px;background:#0c2d39;cursor:pointer;transition:background .12s ease}
.wf-bkg-day:hover{background:#0e3140}
.wf-bkg-day.disabled{opacity:.35;cursor:not-allowed}
.wf-bkg-day.selected{outline:2px solid var(--pill-sel)}

/* Info boxy pod kalendářem (produkt+datum, loď) */
.wf-bkg-picked{margin-top:10px;background:#082a38;border:1px solid #174454;border-radius:6px;padding:10px;font-size:13px;color:var(--mut);display:flex;gap:8px;align-items:flex-start}
.wf-bkg-picked .ico{flex:0 0 16px;height:16px;opacity:.7;margin-top:2px}
.wf-bkg-picked .val{color:var(--ink);text-align:left;}
/* Ikony – inline SVG */
.wf-ico-product{background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="%2397c1cf"><path d="M2 4a2 2 0 0 1 2-2h8l2 2v10a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V4zm10 0H4v10h8V4zM6 7h4v2H6z"/></svg>') no-repeat center/16px 16px}
.wf-ico-boat{background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="%2397c1cf"><path d="M2 10l6-3 6 3-2 4H4l-2-4zm7-6h3l1 2H2l1-2h3l1-2h2l1 2z"/></svg>') no-repeat center/16px 16px}
.wf-ico-person{background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="%2397c1cf"><path d="M8 8a3 3 0 1 0-3-3 3 3 0 0 0 3 3zm0 2c-3 0-6 1.34-6 3v1h12v-1c0-1.66-3-3-6-3z"/></svg>') no-repeat center/16px 16px}
.wf-ico-clock{background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="%2397c1cf"><path d="M8 2a6 6 0 1 0 6 6A6 6 0 0 0 8 2zm1 9H7V5h2z"/><path d="M8 4v4h3"/></svg>') no-repeat center/16px 16px}

/* Osoby */
.wf-persons{margin-top:10px;background:#0b2a36;border:1px solid var(--line);border-radius:8px;padding:10px;display:flex;align-items:center;justify-content:space-between;gap:10px}
.wf-persons-label{display:flex;align-items:center;gap:8px;opacity:.85}
.wf-persons-label .ico{width:16px;height:16px}
.wf-counter{display:flex;align-items:center;gap:8px}
.wf-counter input[type="number"]{width:36px;text-align:center;border:1px solid var(--line);background:var(--pill);color:var(--pill-ink);border-radius:6px;padding:4px 0}
.wf-btn-circle{width:26px;height:26px;border-radius:50%;border:1px solid var(--line);background:var(--pill);color:var(--pill-ink);cursor:pointer;line-height:24px;text-align:center;transition:transform .05s ease,background .12s ease}
.wf-btn-circle:active{transform:translateY(1px)}

/* DIVIDERY */
.wf-divider{position:relative;height:1px;background:var(--line);margin:24px 0}
.wf-divider--boats{margin:10px 0 28px 0}
.wf-divider span{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);background:var(--bg);padding:4px 12px;border:1px solid var(--line);border-radius:14px;font-size:11px;color:var(--mut);letter-spacing:.3px}

/* NOVÝ: Notice divider pro info boxy */
.wf-divider--notice{margin:0px 0 23px 0}

/* NOVÝ: Info box pro orientační časy */
.wf-time-info{
  background:#0b2a36;
  border:1px solid #2a5d3a;
  border-radius:8px;
  padding:12px;
  margin:0 0 20px 0;
  display:flex;
  align-items:flex-start;
  gap:10px;
  font-size:13px;
  line-height:1.4;
}
.wf-time-info .ico{
  flex:0 0 16px;
  height:16px;
  margin-top:2px;
  opacity:.8;
}
.wf-time-info .content{
  color:var(--ink);
}
.wf-time-info .content strong{
  color:#a8d4a8;
  font-weight:600;
  display:block;
  margin-bottom:3px;
}
.wf-time-info .content span{
  color:var(--mut);
  font-size:12px;
  opacity:.9;
}

/* Lodě */
.wf-boats{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:10px}
.wf-boat{display:grid;grid-template-columns:92px 1fr;gap:10px;align-items:center;background:#0b2a36;border:1px solid var(--line);border-radius:10px;padding:8px;cursor:pointer;transition:box-shadow .15s ease, transform .05s ease;text-align:left!important}
.wf-boat *{text-align:left!important}
.wf-boat img{width:92px;height:68px!important;object-fit:cover;border-radius:7px}
.wf-boat h4{margin:0 0 2px 0;font-size:22px!important;color:#fff!important}
.wf-boat small{color:var(--mut)!important;font-size:12px}
.wf-boat strong{font-size:14px}
.wf-boat:hover{box-shadow:0 0 0 2px rgba(255,194,75,.25) inset}
.wf-boat.sel{outline:2px solid var(--pill-sel)}
.wf-boat.unavail{opacity:.4;cursor:not-allowed}

/* Meta blok uvnitř karty lodě: vlevo Seats + varianta, vpravo cena */
.wf-boat-main{display:flex;flex-direction:column;gap:6px}
.wf-boat-meta{display:flex;align-items:center;justify-content:space-between;gap:10px}
.wf-boat-meta-left{display:flex;flex-direction:column;gap:2px}
.wf-boat-meta-left small{color:var(--mut)!important;font-size:12px}
.wf-boat-price{font-size:14px;font-weight:700}

/* === Trip duration UI (odpovídá JS: .wf-dur-ui / .wf-dur-switch / .wf-badge) === */
.wf-dur-ui{margin-left:auto}
.wf-dur-switch{display:inline-flex;align-items:center;gap:2px;background:#0c2d39;border:1px solid var(--line);border-radius:999px;padding:2px}
.wf-dur-switch button{border:none;background:transparent;color:var(--pill-ink);font-size:12px;border-radius:999px;padding:4px 10px;cursor:pointer}
.wf-dur-switch button.sel{background:var(--accent);color:#173342}
.wf-badge{display:inline-block;padding:2px 10px;border-radius:999px;background:#214b5c;border:1px solid var(--line);font-size:12px;color:#cfeaf7}

/* Sloty/Extras – samostatné výšky */
.wf-row{padding-top:30px;display:grid;grid-template-columns:1fr 1fr;gap:14px;align-items:start}
@media (max-width:900px){.wf-row{grid-template-columns:1fr}}

/* Lokální captiony sloupců */
.wf-slots,.wf-extras{position:relative;padding-top:23px}
.wf-slots::before,.wf-extras::before{content:"";position:absolute;left:0;right:0;top:0;height:1px;background:var(--line)}
.wf-slots::after,.wf-extras::after{content:attr(data-caption);position:absolute;left:50%;top:0;transform:translate(-50%,-50%);background:var(--bg);padding:3px 12px;border:1px solid var(--line);border-radius:14px;font-size:11px;color:var(--mut);letter-spacing:.3px;white-space:nowrap}
.wf-slots::after{content:"Start time"} .wf-extras::after{content:"Extras"}

/* Sloty – řádek: vlevo čas (tučně), vpravo cena */
.wf-slots{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;justify-items:center}
.wf-slot{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--pill);color:var(--pill-ink);border:1px solid var(--line);border-radius:9px;padding:6px 8px;font-size:13px;line-height:1.2;cursor:pointer;user-select:none;width:100%;max-width:220px;transition:transform .05s ease,background .12s ease}
.wf-slot .t{font-weight:700}.wf-slot .p{font-size:12px;opacity:.85}
.wf-slot:active{transform:translateY(1px)}
.wf-slot.sel{outline:2px solid var(--pill-sel)}
.wf-slot.unavail{opacity:.45;text-decoration:line-through;cursor:not-allowed}

/* Custom time pill */
.wf-slot.custom{max-width:none}
.wf-slot.custom .custom-wrap{display: contents;align-items:center;gap:8px;width:100%}
.wf-slot.custom input[type="time"]{background:var(--panel);border:1px solid var(--line);color:var(--ink);border-radius:6px;padding:4px 6px}

/* Extras – stejné jako sloty (vlevo název tučně, vpravo cena) */
.wf-extras{background:transparent;border:0;border-radius:0;padding-left:0;padding-right:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:8px}
.wf-extra{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--pill);color:var(--pill-ink);border:1px solid var(--line);border-radius:9px;padding:6px 8px;cursor:pointer;font-size:13px;line-height:1.2}
.wf-extra .t{font-weight:700}.wf-extra .p{font-size:12px;opacity:.85}
.wf-extra:active{transform:translateY(1px)}
.wf-extra.sel{outline:2px solid var(--pill-sel)}

/* Souhrn – 1 řádek; Book Now širší */
.wf-summary-row{display:grid;grid-template-columns:1fr 1fr 1fr 1fr 2fr;gap:10px;align-items:stretch;margin-top:8px}
.wf-box{background:transparent;border:0;border-radius:10px;padding:6px 4px;display:flex;flex-direction:column;justify-content:center}
.wf-box .k{font-size:11px;color:var(--mut);margin:0 0 2px 0}
.wf-box .v{font-size:13px;font-weight:700}
.wf-summary-row .cta{display:flex;align-items:stretch}
.wf-book{width:100%;background:var(--accent);border:none;color:#173342;border-radius:10px;padding:12px 14px;font-weight:800;letter-spacing:.2px;cursor:pointer}
.wf-book[disabled]{opacity:.55;cursor:not-allowed}

/* Pravý panel – skrytý, dokud není vybrán den */
/*.wf-right{display:none}*/
.wf-right.show{display:block}

/* Responsivní rozpad – jeden sloupec */
@media (max-width:980px){
  .wf-summary-row{grid-template-columns:1fr}
}

/* 1) Custom time = přes celou šířku (2 sloupce) */
.wf-slot.custom{
  grid-column: 1 / -1;
  max-width: 100%;
}

/* 2) Number input – skrýt šipky (Chrome/Edge/Safari + Firefox) */
.wf-counter input[type="number"]::-webkit-outer-spin-button,
.wf-counter input[type="number"]::-webkit-inner-spin-button{
  -webkit-appearance: none;
  margin: 0;
}
.wf-counter input[type="number"]{
  -moz-appearance: textfield;
}

/* 3) Zarovnání názvu lodě na stejný levý okraj jako „ikonkové" boxy vlevo */
.wf-bkg-picked{ padding-left: 10px; }
.wf-boat{ padding-left: 10px; }
.wf-boat img{ margin-left: 0; }

/* --- pickery vlevo (jen když není product_id) --- */
.wf-left-pickers{background:#0b2a36;border:1px solid var(--line);border-radius:8px;padding:12px;margin-bottom:12px}
.wf-left-row{display:grid;grid-template-columns:80px 1fr;gap:10px;align-items:center;margin-bottom:10px;}
.wf-left-label{opacity:.9;font-size:12px;}
.wf-left-row select{width:100%;background:#0c2d39;border:1px solid var(--line);border-radius:8px;color:var(--ink);padding:6px 10px;font-size:12px}

/* --- instruktážní panel vpravo --- */
.wf-instructions{display:block}
.wf-instr-box{background:#0b2a36;border:1px solid var(--line);border-radius:10px;padding:14px;margin-top:4px}
.wf-instr-title{font-weight:700;opacity:.9;margin-bottom:6px}
.wf-instr-line{opacity:.9}

/* Custom time přes celou šířku (2 sloupce) – sjednocení */
.wf-slot.custom{grid-column:1/-1;max-width:100%}
.wf-slot.custom input[type="time"]{background:var(--panel);border:1px solid var(--line);color:var(--ink);border-radius:6px;padding:4px 6px}


/* --- mobile: Summary do dvou sloupců a CTA přes celou šířku --- */
@media (max-width: 980px){
  .wf-summary-row{
    grid-template-columns: 1fr 1fr;   /* místo 1 sloupce */
  }
  .wf-summary-row .cta{
    grid-column: 1 / -1;              /* tlačítko na celý řádek */
  }
}

/* --- mobilní přesun TRIP/BOAT boxů (styl wrapperu vpravo) --- */
.wf-mobile-picked{ display:none; }
@media (max-width: 980px){
  .wf-mobile-picked{
    display:block;
    margin: 14px 0 6px;
    display: grid;
    grid-template-columns: 1fr;       /* pod sebou, kompaktně */
    gap: 8px;
  }
  /* zmenšíme margin-top u přesunutých boxů, aby nebyla díra */
  .wf-mobile-picked .wf-bkg-picked{ margin-top: 0; }
}

/* Responzivita pro time-info box */
@media (max-width: 480px){
  .wf-time-info{
    padding: 10px;
    gap: 8px;
  }
  .wf-time-info .content strong{
    font-size: 12px;
  }
  .wf-time-info .content span{
    font-size: 11px;
  }
}