.boat-specs{display:grid;grid-template-columns:1fr 1fr;gap:.4rem 2rem;margin:1rem 0 1.5rem;padding:1rem 1.2rem;background:#fafbfc;border-radius:12px;border:1px solid #e0e6ea}
.boat-specs .spec-row{display:grid;grid-template-columns:1.6rem 1fr auto;gap:.7rem;align-items:center;padding:.55rem 0;border-bottom:1px solid #ecf0f3}
.boat-specs .spec-row:last-child,.boat-specs .spec-row:nth-last-child(2){border-bottom:none}
.boat-specs .spec-icon{color:#ff7a59;font-size:1.05rem}
.boat-specs .spec-label{text-transform:uppercase;font-size:.78rem;letter-spacing:.04em;color:#5a6b7a;font-weight:600}
.boat-specs .spec-val{font-weight:600;color:#1a2332;text-align:right}
@media (max-width:700px){.boat-specs{grid-template-columns:1fr}}

/* ============================================================
   VYPLUJ — Design systém
   Námořní premium: oceánská modř · písek · korálový akcent
   ============================================================ */

:root{
  /* Barvy */
  --navy:        #0a2e44;
  --navy-2:      #0b3d5c;
  --teal:        #12a4b4;
  --teal-dark:   #0c7d8a;
  --coral:       #ff6b4a;
  --coral-dark:  #ed5235;
  --sand:        #f7f2e9;
  --sand-2:      #efe7d8;
  --cream:       #fffdf9;
  --ink:         #142533;   /* 13:1 na cream ✓ */
  --ink-muted:   #4e6072;   /* ~7:1 ✓ */
  --line:        #e4dccd;
  --white:       #ffffff;

  /* Typografie */
  --serif: 'Fraunces', Georgia, 'Times New Roman', serif;
  --sans:  'Inter', system-ui, -apple-system, sans-serif;

  /* Layout */
  --max:    1200px;
  --radius: 16px;
  --radius-sm: 10px;
  --shadow:    0 10px 40px rgba(10,46,68,.10);
  --shadow-sm: 0 4px 18px rgba(10,46,68,.08);
  --shadow-lg: 0 24px 60px rgba(10,46,68,.18);
  --transition: .25s cubic-bezier(.4,0,.2,1);

  /* Spacing */
  --sp-1:.25rem; --sp-2:.5rem; --sp-3:1rem; --sp-4:1.5rem;
  --sp-5:2rem; --sp-6:3rem; --sp-7:5rem;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  font-size:1rem;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--teal-dark);text-decoration:none;transition:color var(--transition)}
a:hover{color:var(--coral-dark)}

h1,h2,h3,h4{font-family:var(--serif);line-height:1.12;color:var(--navy);font-weight:600;letter-spacing:-.01em}
h1{font-size:clamp(2.2rem,6vw,4rem)}
h2{font-size:clamp(1.7rem,4vw,2.7rem)}
h3{font-size:clamp(1.2rem,2.5vw,1.6rem)}

.container{max-width:var(--max);margin-inline:auto;padding-inline:clamp(1rem,4vw,2rem)}
.section{padding-block:clamp(3rem,7vw,6rem)}
.section-sand{background:var(--sand)}
.section-navy{background:var(--navy);color:#dce9f1}
.section-navy h2,.section-navy h3{color:#fff}

.skip-link{position:absolute;left:-999px;top:0;background:var(--navy);color:#fff;padding:.6rem 1rem;z-index:1000}
.skip-link:focus{left:0}

:focus-visible{outline:3px solid var(--teal);outline-offset:2px;border-radius:4px}

/* ---------- Tlačítka ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:var(--sans);font-weight:600;font-size:1rem;
  padding:.85rem 1.6rem;border-radius:999px;border:2px solid transparent;
  cursor:pointer;transition:all var(--transition);text-align:center;line-height:1.2;
}
.btn-primary{background:var(--coral);color:#fff}
.btn-primary:hover{background:var(--coral-dark);color:#fff;transform:translateY(-2px);box-shadow:0 10px 24px rgba(255,107,74,.35)}
.btn-secondary{background:var(--navy-2);color:#fff}
.btn-secondary:hover{background:var(--navy);color:#fff;transform:translateY(-2px)}
.btn-ghost{background:transparent;border-color:currentColor;color:var(--navy)}
.btn-ghost:hover{background:var(--navy);color:#fff;border-color:var(--navy)}
.btn-sm{padding:.5rem 1rem;font-size:.9rem}
.btn-block{width:100%}
.btn-white{background:#fff;color:var(--navy)}
.btn-white:hover{background:var(--sand);color:var(--navy)}

/* ---------- Hlavička ---------- */
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,253,249,.85);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);transition:box-shadow var(--transition)}
.site-header.scrolled{box-shadow:var(--shadow-sm)}
.header-inner{max-width:var(--max);margin-inline:auto;padding:.85rem clamp(1rem,4vw,2rem);display:flex;align-items:center;justify-content:space-between;gap:1rem}
.logo{display:flex;align-items:center;gap:.5rem;font-family:var(--serif);font-weight:700;font-size:1.45rem;color:var(--navy)}
.logo svg{color:var(--teal)}
.logo-img{height:48px;width:auto;display:block}
@media (max-width:560px){.logo-img{height:40px}}
.logo:hover{color:var(--navy)}
.main-nav{display:flex;align-items:center}
.nav-list{list-style:none;display:flex;align-items:center;gap:.4rem}
.nav-list>li>a:not(.btn){padding:.5rem .85rem;border-radius:8px;color:var(--ink);font-weight:500}
.nav-list>li>a:not(.btn):hover{background:var(--sand-2);color:var(--navy)}
.nav-account{color:var(--teal-dark)!important;font-weight:600!important}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.nav-toggle span{width:24px;height:2px;background:var(--navy);border-radius:2px;transition:var(--transition)}

/* ---------- Flash ---------- */
.flash{max-width:var(--max);margin:1rem auto 0;padding:.9rem 1.2rem;border-radius:var(--radius-sm);font-weight:500}
.flash-success{background:#e3f5ee;color:#0b6b4f;border:1px solid #b6e3d0}
.flash-error{background:#fdecea;color:#b3261e;border:1px solid #f5c6c0}
.flash-info{background:#e7f3f7;color:#0c5e6b;border:1px solid #bfe1ea}

/* ---------- HERO ---------- */
.hero{position:relative;min-height:min(88vh,760px);display:flex;align-items:center;color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:-2;
  background:
    radial-gradient(120% 90% at 70% 10%, #1d6f86 0%, transparent 55%),
    linear-gradient(160deg,#0a2e44 0%,#0b3d5c 45%,#0c5e6b 100%);
}
.hero-waves{position:absolute;left:0;right:0;bottom:-1px;z-index:-1;width:100%;color:var(--cream)}
.hero-particles{position:absolute;inset:0;z-index:-1;width:100%;height:100%;pointer-events:none}

/* Live fotogalerie */
.live-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.6rem}
.live-thumb{position:relative;display:block;aspect-ratio:1;border-radius:10px;overflow:hidden;background:var(--sand-2)}
.live-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}
.live-thumb:hover img{transform:scale(1.06)}
.live-vis{position:absolute;top:.3rem;right:.3rem;background:rgba(10,46,68,.7);color:#fff;font-size:.7rem;padding:.1rem .35rem;border-radius:6px}
.gal-block{padding:1.2rem 0;border-bottom:1px solid var(--line)}
.gal-block:last-child{border-bottom:none}
.gal-qr-row{display:flex;gap:1.5rem;flex-wrap:wrap;align-items:flex-start}
.gal-qr{text-align:center;flex-shrink:0}
.gal-qr img{border:1px solid var(--line);border-radius:12px;padding:6px;background:#fff}
.gal-qr p{font-size:.8rem;color:var(--ink-muted);margin:.4rem 0}
.gal-info{flex:1;min-width:200px}

/* Skupinový chat */
.chat-tabs{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:1rem}
.chat-tabs a{padding:.4rem .8rem;border-radius:8px;background:var(--sand);color:var(--navy);font-size:.85rem;font-weight:600}
.chat-tabs a.active{background:var(--teal);color:#fff}
.chat-thread{display:flex;flex-direction:column;gap:.7rem;max-height:460px;overflow-y:auto;padding:1rem;background:var(--sand);border-radius:12px;margin-bottom:1rem}
.chat-msg{max-width:78%;padding:.6rem .85rem;border-radius:12px;background:#fff;box-shadow:0 1px 3px rgba(10,46,68,.08)}
.chat-msg.mine{align-self:flex-end;background:#e7f6f8}
.chat-msg.captain{border-left:3px solid var(--coral)}
.chat-author{font-size:.78rem;font-weight:700;color:var(--teal-dark);margin-bottom:.2rem}
.chat-msg.captain .chat-author{color:var(--coral)}
.chat-body{font-size:.93rem;line-height:1.5;color:var(--ink)}
.chat-meta{font-size:.72rem;color:var(--ink-muted);margin-top:.3rem}
.chat-form{display:flex;gap:.6rem;align-items:flex-end}
.chat-form textarea{flex:1;padding:.6rem .8rem;border:1px solid var(--line);border-radius:10px;font-family:inherit;font-size:.95rem;resize:vertical}
.chat-locked{padding:1.4rem;background:var(--sand);border-radius:12px;text-align:center;color:var(--ink-muted);line-height:1.6}
.chat-voyage-head{margin-bottom:1rem;padding-bottom:.8rem;border-bottom:1px solid var(--line)}
.chat-voyage-eyebrow{font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;color:var(--teal-dark);font-weight:700}
.chat-voyage-head h3{font-size:1.2rem;margin-top:.2rem;color:var(--navy)}
.chat-pill{display:inline-flex;align-items:center;justify-content:center;min-width:1.25rem;height:1.25rem;padding:0 .4rem;border-radius:999px;background:var(--coral);color:#fff;font-size:.72rem;font-weight:700;line-height:1;margin-left:.35rem;vertical-align:middle}
.captain-voyages{font-size:.9rem;margin:.4rem 0 .8rem}
.captain-voyages a{color:var(--teal-dark);font-weight:600}
.captain-voyages a:hover{text-decoration:underline}

/* FAQ accordion */
.faq-list{display:flex;flex-direction:column;gap:.7rem}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden}
.faq-item summary{cursor:pointer;padding:1.1rem 1.3rem;font-weight:600;color:var(--navy);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:'+';font-size:1.4rem;color:var(--teal);font-weight:400;transition:transform .2s}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item summary:hover{color:var(--teal-dark)}
.faq-answer{padding:0 1.3rem 1.2rem;color:var(--ink-muted);line-height:1.65}

/* Rozšířené hodnocení */
.review-group-title{font-size:1.05rem;color:var(--navy);margin:1.6rem 0 .6rem;padding-bottom:.3rem;border-bottom:2px solid var(--sand-2)}
.recommend-toggle{display:flex;gap:1rem}
.recommend-toggle .rec-opt{display:flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border:1px solid var(--line);border-radius:10px;cursor:pointer;font-weight:600}
.recommend-toggle .rec-opt:has(input:checked){border-color:var(--teal);background:#e7f6f8;color:var(--teal-dark)}
.review-subs{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.5rem}
.review-sub{font-size:.76rem;background:var(--sand);color:var(--navy);padding:.2rem .55rem;border-radius:6px;font-weight:600}
.review-sub.rec-yes{background:#e7f6e9;color:#1f7a3a}
.review-sub.rec-no{background:#fdecea;color:#b04a1f}

/* Lodní pokladna */
.kitty-summary{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:1.2rem}
.kitty-summary div{flex:1;min-width:120px;background:var(--sand);border-radius:10px;padding:.8rem 1rem;display:flex;flex-direction:column}
.kitty-summary span{font-size:.74rem;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-muted);font-weight:600}
.kitty-summary strong{font-size:1.2rem;color:var(--navy);margin-top:.2rem}
.kitty-h{font-size:1.05rem;color:var(--navy);margin:1.4rem 0 .6rem;padding-bottom:.3rem;border-bottom:2px solid var(--sand-2)}
.kitty-settle{list-style:none;display:flex;flex-direction:column;gap:.5rem}
.kitty-settle li{background:#e7f6f8;border-radius:10px;padding:.7rem 1rem;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}
.kitty-settle .kitty-amount{margin-left:auto;font-weight:700;color:var(--teal-dark)}
.kitty-balances{margin:.8rem 0}
.kitty-balances summary{cursor:pointer;font-weight:600;color:var(--teal-dark)}
.kitty-balances ul{list-style:none;margin-top:.5rem;display:flex;flex-direction:column;gap:.25rem;font-size:.9rem}
.kitty-balances .pos{color:#1f7a3a;font-weight:700}
.kitty-balances .neg{color:#b04a1f;font-weight:700}
.kitty-form{display:flex;flex-direction:column;gap:.7rem;background:var(--sand);padding:1.1rem;border-radius:12px;margin-bottom:1rem}
.kitty-row{display:flex;gap:.7rem;flex-wrap:wrap}
.kitty-row label{flex:1;min-width:140px}
.kitty-form label{display:flex;flex-direction:column;font-size:.85rem;font-weight:600;color:var(--navy);gap:.3rem}
.kitty-form input,.kitty-form select{padding:.55rem .7rem;border:1px solid var(--line);border-radius:9px;font-family:inherit;font-size:.95rem}
.kitty-split{border:none;display:flex;flex-direction:column;gap:.4rem;padding:0}
.kitty-split .check-inline{flex-direction:row !important;align-items:center;gap:.5rem;font-weight:500;font-size:.9rem}
.kitty-split .check-inline input{width:auto;flex:none;margin:0}
.kitty-share-row{flex-direction:row !important;align-items:center;justify-content:space-between;gap:1rem;font-weight:500 !important}
.kitty-share-row input{width:120px}
.kitty-list{list-style:none;display:flex;flex-direction:column;gap:.5rem}
.kitty-item{background:#fff;border:1px solid var(--line);border-radius:10px;padding:.7rem .9rem;display:flex;align-items:flex-start;gap:.6rem}
.kitty-item-main{display:flex;justify-content:space-between;gap:.6rem;flex:1}
.kitty-item-main .kitty-amount{font-weight:700;color:var(--navy)}
.kitty-item-meta{font-size:.8rem;color:var(--ink-muted)}
.kitty-item{flex-wrap:wrap}
.kitty-item-meta{flex-basis:100%}
.kitty-shares{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.3rem}
.kitty-shares span{background:var(--sand);padding:.1rem .4rem;border-radius:5px}
.kitty-del{background:none;border:none;color:var(--coral);font-size:1.3rem;cursor:pointer;line-height:1;padding:0 .3rem}
.kitty-hint{margin-top:.5rem;font-size:.88rem;font-weight:600}
.kitty-hint .ok{color:#1f7a3a}
.kitty-hint .bad{color:#b04a1f}
.poi-pin{font-size:20px;line-height:1;text-align:center;background:none;border:none}
.sm-pop strong{font-size:.95rem;color:#0a2e44}
.sm-name{font-weight:600;color:#0c7d8a;margin:.2rem 0}
.sm-row{display:flex;justify-content:space-between;gap:1rem;font-size:.82rem;padding:.1rem 0;border-top:1px solid #eef2f5}
.sm-row span{color:#5a6b7a}
.sm-more{font-size:.75rem;color:#5a6b7a;margin-top:.4rem;font-style:italic}
.sm-depth{background:#e7f6f8;border-radius:6px;padding:.35rem .55rem;margin:.4rem 0;font-size:.9rem;color:#0a2e44}
.sm-depth b{color:#0c7d8a}
.route-pin{font-size:22px;line-height:1;text-align:center;background:none;border:none}
.route-dot{background:#12a4b4 !important;border:2px solid #fff;border-radius:50%;box-shadow:0 1px 4px rgba(0,0,0,.4)}
.wp-tip{background:#0a2e44;color:#fff;border:none;font-weight:600;font-size:.75rem;border-radius:6px}
.wp-tip::before{border-top-color:#0a2e44}
.wp-pop label{display:flex;flex-direction:column;font-size:.78rem;font-weight:600;gap:.25rem;margin-bottom:.5rem}
.wp-pop input{padding:.4rem .5rem;border:1px solid #ccc;border-radius:6px}
.wp-btns{display:flex;gap:.3rem;flex-wrap:wrap}

/* Meteo dashboard */
.weather-windy{width:100%;border-radius:14px;border:1px solid var(--line)}
.weather-note{font-size:.82rem;color:var(--ink-muted);margin:.5rem 0 1rem}
.weather-h{font-size:1.05rem;color:var(--navy);margin:.6rem 0 .7rem}
.wf-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.6rem}
.wf-day{background:var(--sand);border-radius:10px;padding:.7rem;text-align:center}
.wf-date{font-weight:700;color:var(--navy);text-transform:capitalize;font-size:.85rem}
.wf-code{font-size:.82rem;margin:.35rem 0;color:var(--ink)}
.wf-temp{font-weight:700;color:var(--navy)}
.wf-wind{font-size:.8rem;color:var(--teal-dark);margin-top:.25rem}
.wf-gust{color:var(--ink-muted)}
.weather-loading{color:var(--ink-muted)}

/* E-learning */
.el-progress{height:10px;background:var(--sand-2);border-radius:6px;overflow:hidden;margin-bottom:.4rem}
.el-bar{height:100%;background:linear-gradient(90deg,var(--teal),var(--teal-dark));border-radius:6px;transition:width .3s}
.lesson-list{display:flex;flex-direction:column;gap:.5rem}
.lesson-item{display:flex;align-items:center;gap:.8rem;padding:.9rem 1.1rem;background:#fff;border:1px solid var(--line);border-radius:10px;color:var(--navy);font-weight:600}
.lesson-item:hover{border-color:var(--teal)}
.lesson-item.done{background:#eef9f0;border-color:#bfe3c8}
.lesson-ico{font-size:1.2rem}
.lesson-content{line-height:1.7;color:var(--ink);white-space:pre-line;background:var(--sand);padding:1.2rem;border-radius:10px}
.quiz-q{border:none;padding:0;margin:0 0 1.3rem}
.quiz-q legend{font-weight:700;color:var(--navy);font-size:1.02rem;margin-bottom:.6rem;padding:0;display:block;width:100%}
.quiz-q .quiz-a{display:flex;align-items:center;gap:.7rem;padding:.7rem .9rem;margin-bottom:.5rem;border:1.5px solid var(--line);border-radius:10px;cursor:pointer;transition:border-color .15s,background .15s;font-size:.95rem}
.quiz-q .quiz-a:hover{border-color:var(--teal)}
.quiz-q .quiz-a:has(input:checked){border-color:var(--teal);background:#e7f6f8;font-weight:600}
.quiz-q .quiz-a input{width:auto;flex:none;accent-color:var(--teal);transform:scale(1.15)}
.quiz-cat{font-size:.8rem;text-transform:uppercase;letter-spacing:.06em;color:var(--teal-dark);margin:1.4rem 0 .6rem;padding-bottom:.3rem;border-bottom:2px solid var(--sand-2)}
.quiz-a.static{cursor:default}
.quiz-a.static.correct{border-color:#1f7a3a;background:#eef9f0;font-weight:600;color:#1f7a3a}
.quiz-a.static.chosen-bad{border-color:#b04a1f;background:#fdecea;color:#b04a1f}
.quiz-q.result legend .q-ok{color:#1f7a3a;font-size:.82rem;font-weight:700}
.quiz-q.result legend .q-bad{color:#b04a1f;font-size:.82rem;font-weight:700}
.quiz-score{text-align:center;padding:1.5rem;border-radius:14px;margin-bottom:1.5rem}
.quiz-score strong{display:block;font-size:2.6rem;line-height:1}
.quiz-score span{display:block;font-weight:600;margin:.3rem 0}
.quiz-score p{margin:.4rem 0 0}
.quiz-score.good{background:#eef9f0;color:#1f7a3a}
.quiz-score.mid{background:#fff4e6;color:#b04a1f}
.quiz-score.bad{background:#fdecea;color:#b04a1f}
.cap-nav a.active .chat-pill{background:#fff;color:var(--coral)}

/* Kapitánský portál */
.cap-body{background:var(--sand);min-height:100vh;display:flex;flex-direction:column}
.cap-topbar{background:var(--navy);display:flex;align-items:center;justify-content:space-between;padding:.7rem clamp(1rem,4vw,2rem);gap:1rem}
.cap-brand{display:flex;align-items:center;gap:.7rem}
.cap-brand img{height:38px;width:auto}
.cap-tag{color:rgba(255,255,255,.7);font-size:.8rem;font-weight:600;border-left:1px solid rgba(255,255,255,.25);padding-left:.7rem}
.cap-user{display:flex;align-items:center;gap:.9rem;color:#fff;font-weight:600;font-size:.92rem}
.cap-user .btn-ghost{color:#fff;border-color:rgba(255,255,255,.5)}
.cap-main{flex:1}
.cap-foot{text-align:center;padding:1.4rem;color:var(--ink-muted);font-size:.82rem}
.cap-login{max-width:420px;margin:3rem auto;padding:0 1rem}
.cap-wrap{max-width:var(--max);margin-inline:auto;padding:2rem clamp(1rem,4vw,2rem)}
.cap-h1{font-size:2rem;margin-bottom:1.4rem}
.cap-layout{display:grid;grid-template-columns:280px 1fr;gap:1.5rem;align-items:start}
.cap-nav{display:flex;flex-direction:column;gap:.5rem}
.cap-nav a{display:block;padding:.8rem 1rem;border-radius:12px;background:#fff;color:var(--navy);box-shadow:0 1px 3px rgba(10,46,68,.06)}
.cap-nav a.active{background:var(--teal);color:#fff}
.cap-nav a strong{display:block;font-size:.95rem;line-height:1.3}
.cap-nav-meta{display:block;font-size:.75rem;opacity:.8;margin-top:.25rem}
.cap-content{display:flex;flex-direction:column;gap:1.5rem;min-width:0}
.cap-voyage{padding:0;overflow:hidden}
.cap-cover{height:200px;overflow:hidden}
.cap-cover img{width:100%;height:100%;object-fit:cover}
.cap-cover-empty{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--teal-dark),var(--navy));color:#fff;font-family:var(--serif);font-size:1.6rem}
.cap-voyage-title{font-size:1.5rem;margin:1.2rem 1.4rem .2rem}
.cap-place{color:var(--ink-muted);margin:0 1.4rem 1rem}
.cap-facts{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem;padding:0 1.4rem 1.2rem}
.cap-facts div{display:flex;flex-direction:column}
.cap-facts span{font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-muted);font-weight:600}
.cap-facts strong{font-size:1rem;color:var(--navy);margin-top:.2rem}
.cap-voyage .btn{margin:0 1.4rem 1.4rem}
@media (max-width:760px){.cap-layout{grid-template-columns:1fr}.cap-tag{display:none}}
.hero-inner{max-width:var(--max);margin-inline:auto;padding:5rem clamp(1rem,4vw,2rem) 7rem;width:100%}
.hero h1{color:#fff;max-width:16ch;text-shadow:0 2px 30px rgba(0,0,0,.2)}
.hero .lead{font-size:clamp(1.05rem,2vw,1.35rem);max-width:46ch;margin-top:1.2rem;color:#d6e6ee}
.eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--sans);font-weight:600;letter-spacing:.12em;text-transform:uppercase;font-size:.78rem;color:var(--teal);background:rgba(18,164,180,.14);padding:.4rem .9rem;border-radius:999px;backdrop-filter:blur(4px)}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;margin-top:2rem}
.hero-stats{display:flex;gap:2.5rem;margin-top:3rem;flex-wrap:wrap}
.hero-stat strong{display:block;font-family:var(--serif);font-size:2rem;color:#fff}
.hero-stat span{font-size:.85rem;color:#aecdda;letter-spacing:.04em}

/* ---------- Vyhledávací lišta ---------- */
.search-bar{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:1rem;display:grid;grid-template-columns:repeat(4,1fr) auto;gap:.6rem;max-width:980px;margin:1.5rem auto 0;position:relative;z-index:5}
.search-bar .field{display:flex;flex-direction:column;padding:.3rem .7rem}
.search-bar label{font-size:.7rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-muted)}
.search-bar select,.search-bar input{border:none;background:none;font-family:var(--sans);font-size:.98rem;color:var(--ink);padding:.2rem 0;outline:none}

/* ---------- Mřížka plaveb ---------- */
.section-head{text-align:center;max-width:60ch;margin:0 auto 2.5rem}
.section-head p{color:var(--ink-muted);margin-top:.6rem;font-size:1.05rem}
.voyages-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.6rem}

.voyage-card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform var(--transition),box-shadow var(--transition);display:flex;flex-direction:column;position:relative}
.voyage-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.voyage-media{position:relative;aspect-ratio:16/10;overflow:hidden;background:linear-gradient(135deg,#0c5e6b,#0b3d5c)}
.voyage-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.voyage-card:hover .voyage-media img{transform:scale(1.06)}
.voyage-badge{position:absolute;top:.9rem;left:.9rem;background:var(--coral);color:#fff;font-size:.72rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:.35rem .7rem;border-radius:999px}
.voyage-badge.done{background:var(--navy-2)}
.voyage-fav{position:absolute;top:.9rem;right:.9rem;background:rgba(255,255,255,.9);width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--coral);font-size:1.1rem;border:none;cursor:pointer}
.voyage-body{padding:1.3rem 1.4rem 1.5rem;display:flex;flex-direction:column;flex:1}
.voyage-place{font-size:.8rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--teal-dark);display:flex;align-items:center;gap:.4rem}
.voyage-card h3{margin:.4rem 0 .5rem;font-size:1.35rem}
.voyage-card h3 a{color:var(--navy)}
.voyage-card h3 a:hover{color:var(--teal-dark)}
.voyage-meta{display:flex;flex-wrap:wrap;gap:.4rem .9rem;font-size:.88rem;color:var(--ink-muted);margin-bottom:.8rem}
.voyage-meta span{display:inline-flex;align-items:center;gap:.3rem}
.voyage-perex{color:var(--ink-muted);font-size:.95rem;margin-bottom:1rem;flex:1}
.voyage-foot{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-top:1rem;border-top:1px solid var(--line)}
.voyage-price strong{font-family:var(--serif);font-size:1.5rem;color:var(--navy)}
.voyage-price span{font-size:.8rem;color:var(--ink-muted);display:block}
.stars{color:#e7b008;letter-spacing:1px}
.stars .star{opacity:.28}
.stars .star.on{opacity:1}
.rating-line{display:flex;align-items:center;gap:.4rem;font-size:.85rem;color:var(--ink-muted)}

/* ---------- Filtry (stránka plaveb) ---------- */
.filters{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.2rem;display:flex;flex-wrap:wrap;gap:1rem;align-items:flex-end;margin-bottom:2rem;box-shadow:var(--shadow-sm)}
.filters .field{display:flex;flex-direction:column;gap:.3rem;min-width:150px;flex:1}
.filters label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-muted)}
.filters select,.filters input{padding:.6rem .8rem;border:1px solid var(--line);border-radius:var(--radius-sm);font-family:var(--sans);font-size:.95rem;background:var(--cream)}

/* ---------- Detail plavby ---------- */
.voyage-hero{position:relative;min-height:50vh;display:flex;align-items:flex-end;color:#fff;background:linear-gradient(135deg,#0c5e6b,#0a2e44)}
.voyage-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(10,46,68,.85),rgba(10,46,68,.15))}
.voyage-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.55}
.voyage-hero-inner{position:relative;z-index:2;max-width:var(--max);margin-inline:auto;padding:3rem clamp(1rem,4vw,2rem);width:100%}
.voyage-hero h1{color:#fff}
.detail-grid{display:grid;grid-template-columns:1fr 360px;gap:2.5rem;align-items:start}
.detail-main h2{margin:2rem 0 1rem}
.fact-row{display:flex;flex-wrap:wrap;gap:1.2rem;margin:1.5rem 0;padding:1.2rem;background:var(--sand);border-radius:var(--radius)}
.fact{display:flex;flex-direction:column;min-width:120px}
.fact span{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-muted);font-weight:600}
.fact strong{font-family:var(--serif);font-size:1.15rem;color:var(--navy)}

.itinerary{list-style:none;position:relative;margin-left:1rem}
.itinerary::before{content:"";position:absolute;left:0;top:6px;bottom:6px;width:2px;background:var(--line)}
.itinerary li{position:relative;padding:0 0 1.6rem 1.8rem}
.itinerary li::before{content:"";position:absolute;left:-5px;top:4px;width:12px;height:12px;border-radius:50%;background:var(--coral);border:2px solid #fff;box-shadow:0 0 0 2px var(--coral)}
.itinerary .day{font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--teal-dark)}
.itinerary h3{font-size:1.2rem;margin:.2rem 0}
.itinerary .route{font-size:.9rem;color:var(--ink-muted);font-weight:500}

.poi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}
.poi-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);padding:1.1rem}
.poi-type{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:.2rem .55rem;border-radius:999px;display:inline-block;margin-bottom:.5rem}
.poi-type.misto{background:#e7f3f7;color:var(--teal-dark)}
.poi-type.jidlo{background:#fdeee9;color:var(--coral-dark)}
.poi-type.restaurace{background:#f3eedf;color:#8a6d1c}
.poi-type.aktivita{background:#eae7f7;color:#5b4b9c}
.poi-card h4{font-family:var(--serif);font-size:1.1rem;margin-bottom:.3rem;color:var(--navy)}
.poi-card p{font-size:.92rem;color:var(--ink-muted)}

/* Booking box (sticky) */
.booking-box{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.6rem;position:sticky;top:90px}
.booking-box .price{font-family:var(--serif);font-size:2.2rem;color:var(--navy)}
.booking-box .price small{font-size:1rem;color:var(--ink-muted);font-weight:400}
.booking-box .row{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;padding:.5rem 0;border-bottom:1px solid var(--line);font-size:.95rem;flex-wrap:wrap}
.booking-box .row span{color:var(--ink-muted);flex-shrink:0}
.booking-box .row strong{text-align:right}
.share-row{display:flex;gap:.5rem;margin-top:1rem}
.share-row a,.share-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.6rem;border-radius:var(--radius-sm);background:var(--sand);color:var(--navy);font-size:.85rem;font-weight:600;border:none;cursor:pointer}
.share-row a:hover,.share-btn:hover{background:var(--sand-2)}

/* ---------- Recenze ---------- */
.review{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.4rem;margin-bottom:1rem}
.review-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}
.review-author{font-weight:600;color:var(--navy)}
.review .date{font-size:.82rem;color:var(--ink-muted)}

/* ---------- Kapitáni ---------- */
.captains-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.6rem;align-items:stretch}
.captain-card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);text-align:center;padding-bottom:1.5rem;display:flex;flex-direction:column;height:100%}
.captain-card .rating-line{justify-content:center}
.captain-card .captain-bio{flex:1 0 auto}
.captain-card .btn{align-self:center;margin-top:.2rem}
.captain-photo{aspect-ratio:1;background:linear-gradient(135deg,#0c5e6b,#0b3d5c);display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--serif);font-size:3rem}
.captain-photo img{width:100%;height:100%;object-fit:cover}
.captain-card h3{margin:1rem 0 .3rem}
.captain-card .role{color:var(--teal-dark);font-weight:600;font-size:.9rem}
.captain-card p{padding:0 1.4rem;color:var(--ink-muted);font-size:.92rem;margin-top:.6rem}

/* ---------- Formuláře ---------- */
.form-card{max-width:460px;margin:3rem auto;background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:2.2rem}
.form-card.wide{max-width:680px}
.form-group{margin-bottom:1.1rem}
.form-group label{display:block;font-weight:600;font-size:.9rem;margin-bottom:.35rem;color:var(--navy)}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem .9rem;border:1px solid var(--line);border-radius:var(--radius-sm);font-family:var(--sans);font-size:1rem;background:var(--cream);transition:border var(--transition)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--teal);background:#fff}
.form-group textarea{min-height:120px;resize:vertical}
.form-hint{font-size:.82rem;color:var(--ink-muted);margin-top:.3rem}
.checkbox-row{display:flex;align-items:flex-start;gap:.6rem;font-size:.9rem}
.checkbox-row input{width:auto;margin-top:.25rem}

/* ---------- Účet zákazníka ---------- */
.account-layout{display:grid;grid-template-columns:240px 1fr;gap:2rem;align-items:start}
.account-nav{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1rem;position:sticky;top:90px}
.account-nav a{display:block;padding:.65rem .9rem;border-radius:var(--radius-sm);color:var(--ink);font-weight:500}
.account-nav a:hover,.account-nav a.active{background:var(--sand);color:var(--navy)}
.panel{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem;margin-bottom:1.5rem}
.table{width:100%;border-collapse:collapse}
.table th,.table td{padding:.8rem;text-align:left;border-bottom:1px solid var(--line);font-size:.93rem}
.table th{font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-muted)}
.pill{display:inline-block;padding:.25rem .65rem;border-radius:999px;font-size:.78rem;font-weight:600}
.pill.pending{background:#fdf2e0;color:#9a6b12}
.pill.paid{background:#e3f5ee;color:#0b6b4f}
.pill.completed{background:#e7f0f7;color:#0b3d5c}
.pill.cancelled{background:#fdecea;color:#b3261e}

/* ---------- Komunikace ---------- */
.thread{display:flex;flex-direction:column;gap:.8rem;margin-bottom:1.5rem}
.msg{max-width:75%;padding:.8rem 1.1rem;border-radius:var(--radius);font-size:.95rem}
.msg.user{align-self:flex-end;background:var(--navy-2);color:#fff;border-bottom-right-radius:4px}
.msg.system{align-self:flex-start;background:var(--sand);border-bottom-left-radius:4px}
.msg .meta{font-size:.72rem;opacity:.7;margin-top:.3rem}

/* ---------- 404 ---------- */
.error-page{text-align:center;padding:6rem 1rem}
.error-page h1{font-size:7rem;color:var(--teal)}

/* ---------- Zápatí ---------- */
.site-footer{background:var(--navy);color:#b7cdd9;padding-top:3.5rem}
.footer-inner{max-width:var(--max);margin-inline:auto;padding:0 clamp(1rem,4vw,2rem) 2.5rem;display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:2rem}
.footer-brand p{margin-top:.8rem;font-size:.92rem;max-width:34ch}
.logo-footer{color:#fff;font-size:1.3rem}
.logo-footer img{height:46px;width:auto;display:block}
.footer-col h3{color:#fff;font-size:1rem;margin-bottom:.9rem}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:.5rem}
.footer-col a{color:#b7cdd9;font-size:.92rem}
.footer-col a:hover{color:var(--teal)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);max-width:var(--max);margin-inline:auto;padding:1.2rem clamp(1rem,4vw,2rem);display:flex;justify-content:space-between;align-items:center;font-size:.82rem;flex-wrap:wrap;gap:.5rem}
.footer-credit{color:#8aa4b3}
.footer-credit a{color:#b7cdd9;text-underline-offset:3px}
.footer-credit a:hover{color:#fff}

/* ---------- Utility ---------- */
.text-center{text-align:center}
.mt-1{margin-top:1rem}.mt-2{margin-top:2rem}.mb-2{margin-bottom:2rem}
.empty{text-align:center;padding:3rem 1rem;color:var(--ink-muted)}

/* ---------- Hlavička stránky / obecné ---------- */
.page-head{background:linear-gradient(160deg,var(--sand),var(--cream));padding:3.2rem 0 2.4rem;border-bottom:1px solid var(--line)}
.page-head h1{font-family:var(--serif);font-size:clamp(2rem,4vw,3rem);color:var(--navy);margin-top:.6rem}
.lead{font-size:clamp(1.02rem,1.6vw,1.2rem);color:var(--ink-muted);max-width:60ch;margin-top:.7rem;line-height:1.6}
.narrow{max-width:760px}
.center{text-align:center;margin-inline:auto}
.muted{color:var(--ink-muted)}
.back-link{display:inline-block;color:var(--teal-dark);font-weight:600;font-size:.9rem;margin-bottom:1rem}
.back-link:hover{color:var(--navy)}

/* ---------- Statistiky / O nás ---------- */
.stats-band{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;background:var(--navy);border-radius:var(--radius);padding:2rem;color:#fff}
.stats-band .stat{text-align:center}
.stats-band .stat strong{display:block;font-family:var(--serif);font-size:2.2rem;color:var(--teal)}
.stats-band .stat span{font-size:.88rem;color:#b7cdd9}
.prose h2{font-family:var(--serif);color:var(--navy);margin:2rem 0 .7rem}
.prose p{color:var(--ink-muted);line-height:1.75;margin-bottom:1rem}
.check-list{list-style:none;margin:1rem 0}
.check-list li{position:relative;padding-left:1.8rem;margin-bottom:.6rem;color:var(--ink)}
.check-list li::before{content:"⚓";position:absolute;left:0;color:var(--teal)}
.cta-inline{display:flex;gap:1rem;flex-wrap:wrap;margin-top:2rem}
.cta-inline.center{justify-content:center}

/* ---------- Kontakt ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:2.5rem;align-items:start}
.contact-info h2{font-family:var(--serif);color:var(--navy);margin-bottom:.8rem}
.contact-info p{color:var(--ink-muted);margin-bottom:.7rem;line-height:1.6}
.contact-info a{color:var(--teal-dark);font-weight:600}
.contact-form-wrap{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:2rem}

/* ---------- Formuláře (label-wrap styl) ---------- */
.form .field{display:block;margin-bottom:1.1rem}
.form .field>span{display:block;font-weight:600;font-size:.9rem;margin-bottom:.35rem;color:var(--navy)}
.form input,.form select,.form textarea{width:100%;padding:.75rem .9rem;border:1px solid var(--line);border-radius:var(--radius-sm);font-family:var(--sans);font-size:1rem;background:var(--cream);transition:border var(--transition)}
.form input:focus,.form select:focus,.form textarea:focus{border-color:var(--teal);background:#fff;outline:2px solid rgba(18,164,180,.2)}
.form textarea{resize:vertical}
.card-form{max-width:640px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:2rem;margin-top:1.5rem}
.notice{padding:.85rem 1.1rem;border-radius:var(--radius-sm);margin-bottom:1rem;font-size:.93rem}
.notice.success{background:#e3f5ee;color:#0b6b4f}
.notice.error{background:#fdecea;color:#b3261e}

/* ---------- Hvězdičkový vstup ---------- */
.rating-field{border:none;margin-bottom:1.4rem}
.rating-field legend{font-weight:600;color:var(--navy);margin-bottom:.5rem}
.star-input{display:inline-flex;flex-direction:row-reverse;gap:.15rem}
.star-input input{position:absolute;opacity:0;width:0;height:0}
.star-input label{font-size:2rem;color:var(--line);cursor:pointer;transition:color .15s}
.star-input label.hl,.star-input input:checked ~ label{color:#f2b705}
.star-input:hover label{color:var(--line)}
.star-input label.hl{color:#f2b705}

/* ---------- Ověření e-mailu ---------- */
.verify-icon{width:84px;height:84px;border-radius:50%;background:#e3f5ee;color:#0b6b4f;display:flex;align-items:center;justify-content:center;font-size:2.6rem;margin:0 auto 1.4rem}
.verify-icon.warn{background:#fdf2e0;color:#9a6b12}

/* ---------- Kapitáni (rozšíření) ---------- */
.captain-avatar{width:120px;height:120px;border-radius:50%;margin:1.4rem auto .4rem;background:linear-gradient(135deg,#0c5e6b,#0b3d5c);display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--serif);font-size:2.6rem;overflow:hidden}
.captain-avatar img{width:100%;height:100%;object-fit:cover}
.captain-avatar.lg{width:160px;height:160px;font-size:3.4rem;margin:0}
.captain-card h2{margin:.3rem 0;font-size:1.3rem}
.captain-card h2 a{color:var(--navy)}
.captain-card h2 a:hover{color:var(--teal-dark)}
.captain-exp{color:var(--teal-dark);font-weight:600;font-size:.88rem}
.captain-bio{padding:0 1.4rem;color:var(--ink-muted);font-size:.92rem;margin:.6rem 0 1rem}
.captain-detail-head{display:flex;gap:2rem;align-items:center;flex-wrap:wrap;margin-bottom:1.5rem}
.captain-detail-head h1{font-family:var(--serif);color:var(--navy);font-size:clamp(1.8rem,3.5vw,2.6rem)}
.captain-meta{display:flex;gap:1.6rem;flex-wrap:wrap;margin-top:1rem}
.captain-meta div{display:flex;flex-direction:column}
.captain-meta span{font-size:.74rem;text-transform:uppercase;letter-spacing:.05em;color:var(--ink-muted)}
.captain-meta strong{color:var(--navy)}
.captain-detail-bio{background:var(--sand);border-radius:var(--radius);padding:1.6rem;margin-bottom:2rem;line-height:1.7;color:var(--ink)}
.captain-detail h2{font-family:var(--serif);color:var(--navy);margin:2rem 0 1rem}
.reviews-list{display:grid;gap:1.2rem}

/* ---------- Reveal animace ---------- */
[data-reveal]{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
[data-reveal].in{opacity:1;transform:none}

/* ---------- Responzivita ---------- */
@media (max-width:980px){
  .detail-grid{grid-template-columns:1fr}
  .booking-box{position:static}
  .account-layout{grid-template-columns:1fr}
  .account-nav{position:static;display:flex;flex-wrap:wrap;gap:.4rem}
  .footer-inner{grid-template-columns:1fr 1fr}
  .stats-band{grid-template-columns:repeat(2,1fr)}
  .contact-grid{grid-template-columns:1fr}
}
@media (max-width:760px){
  .site-header{background:#fffdf9;backdrop-filter:none}
  .nav-toggle{display:flex;position:relative;z-index:120}
  .nav-list{position:fixed;inset:0 0 0 auto;width:min(80%,320px);background:#fffdf9;flex-direction:column;align-items:stretch;padding:5rem 1.5rem 2rem;gap:.3rem;transform:translateX(100%);transition:transform .3s ease;box-shadow:var(--shadow-lg);z-index:110}
  .nav-list.open{transform:translateX(0)}
  .nav-list.open::before{content:"";position:fixed;inset:0;background:rgba(11,61,92,.45);z-index:-1}
  .nav-list>li>a:not(.btn){display:block}
  .nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
  .nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .search-bar{grid-template-columns:1fr 1fr;margin-top:1.5rem}
  .search-bar .btn{grid-column:1/-1}
  .footer-inner{grid-template-columns:1fr}
  .hero-stats{gap:1.5rem}
}
@media (max-width:440px){
  .search-bar{grid-template-columns:1fr}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto}
}
