:root{
  --bg:#f2f5f4;
  --surface:#ffffff;
  --surface-2:#edf3f1;
  --surface-3:#e2eceb;
  --line:#d3dedb;
  --line-strong:#a8bcb5;
  --text:#111e1a;
  --muted:#415049;
  --soft:#637068;
  --primary:#0f766e;
  --primary-strong:#0a5a54;
  --primary-soft:#dff5f1;
  --primary-ink:#ffffff;
  --shadow-sm:0 2px 12px rgba(15,35,30,.06);
  --shadow-md:0 14px 36px rgba(15,35,30,.09);
  --shadow-lg:0 24px 60px rgba(15,35,30,.13);
  --radius-sm:14px;
  --radius-md:20px;
  --radius-lg:26px;
  --container:1220px;
}

[data-theme="dark"]{
  --bg:#070c0b;
  --surface:#111a18;
  --surface-2:#182320;
  --surface-3:#1f2e2a;
  --line:#2a3835;
  --line-strong:#3d5550;
  --text:#eef4f2;
  --muted:#b8cdc8;
  --soft:#7d9e98;
  --primary:#4dbfb5;
  --primary-strong:#7dd9d2;
  --primary-soft:#0d2825;
  --primary-ink:#040e0c;
  --shadow-sm:0 2px 12px rgba(0,0,0,.6);
  --shadow-md:0 14px 36px rgba(0,0,0,.7);
  --shadow-lg:0 24px 60px rgba(0,0,0,.85);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
/* ── SCROLL OFFSET (topbar výška ~64px) ── */
#app, #pdf, #pricing, #recenze, #recenzie, #opinie {
  scroll-margin-top: 72px;
}

body{margin:0;background:var(--bg);color:var(--text);font:16px/1.65 Inter,system-ui,sans-serif;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
button,input,textarea,select{font:inherit}
img,svg{display:block;max-width:100%}
:focus-visible{outline:2px solid var(--primary);outline-offset:3px;border-radius:10px}

.wrap{max-width:var(--container);margin:0 auto;padding:0 24px}
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}
.section{padding:56px 0}
.muted{color:var(--muted)}

.skip-link{position:absolute;left:-999px;top:10px;background:var(--surface);color:var(--text);padding:10px 14px;border-radius:12px;border:1px solid var(--line);z-index:200}
.skip-link:focus{left:10px}

/* ── TOPBAR ── */
.topbar{position:sticky;top:0;z-index:60;background:color-mix(in srgb,var(--bg) 90%,transparent);backdrop-filter:blur(16px);border-bottom:1px solid var(--line)}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:68px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;letter-spacing:-.03em}
.brand span{font-size:19px}
.logo{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,var(--primary),#4db8af);display:grid;place-items:center;color:var(--primary-ink);box-shadow:inset 0 1px 0 rgba(255,255,255,.15),var(--shadow-sm)}
.logo svg{width:24px;height:24px}
.top-nav{display:flex;gap:4px;align-items:center;font-size:14px}
.top-nav a{padding:6px 12px;border-radius:999px;color:var(--muted);font-weight:500}
.top-nav a:hover{background:var(--surface-2);color:var(--text)}
.top-actions{display:flex;align-items:center;gap:8px}
/* ── LANG SWITCH — desktop: inline, mobile: dropdown ── */
.lang-switch{
  display:flex;gap:2px;align-items:center;
  position:relative;
}
.lang-switch button,.theme-btn{border:0;background:transparent;cursor:pointer}

/* Trigger tlačítko — skryté na desktopu, viditelné na mobilu */
.lang-trigger{
  display:none;
  align-items:center;gap:5px;
  padding:5px 9px;border-radius:9px;
  border:1px solid var(--line);
  background:var(--surface);
  color:var(--text);cursor:pointer;
  font-size:13px;font-weight:600;
}
.lang-trigger .flag{font-size:18px;line-height:1}
.lang-chev{
  width:10px;height:6px;flex-shrink:0;
  stroke:var(--muted);
  transition:transform .2s;
}
.lang-switch.lang-open .lang-chev{transform:rotate(180deg)}

/* Kontejner s options — desktop: flex inline, mobile: dropdown panel */
.lang-opts{display:flex;gap:2px;align-items:center}

.lang-btn{
  display:inline-flex;align-items:center;gap:5px;
  padding:6px 10px;border-radius:8px;
  font-weight:600;font-size:12px;color:var(--muted);
  text-decoration:none;
  transition:background .15s,color .15s;
}
.lang-btn:hover{background:var(--surface-2);color:var(--text)}
.lang-btn.active{background:var(--primary-soft);color:var(--primary);font-weight:700}
.theme-btn{width:36px;height:36px;border:1px solid var(--line);border-radius:10px;background:var(--surface);color:var(--text);font-size:15px}

/* ── HERO ── */
.hero{padding:48px 0 40px}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:stretch}
.hero-copy{padding:40px}
.hero-side{padding:36px 32px;display:flex;flex-direction:column;gap:0}
.eyebrow{display:inline-flex;align-items:center;padding:5px 12px;border-radius:999px;background:var(--primary-soft);color:var(--primary);font-weight:700;font-size:12px;letter-spacing:.01em;margin-bottom:20px}
h1{margin:0 0 20px;font-size:clamp(36px,4.5vw,58px);line-height:1.03;letter-spacing:-.045em;color:var(--text)}
h2{margin:0;color:var(--text);font-size:clamp(26px,3vw,38px);line-height:1.06;letter-spacing:-.04em}
h3{margin:0;color:var(--text);font-size:18px;line-height:1.3;letter-spacing:-.02em}
.lead{margin:0 0 28px;color:var(--muted);font-size:clamp(16px,1.6vw,19px);font-weight:500;line-height:1.55;max-width:46ch}
.hero-cta{display:flex;gap:10px;flex-wrap:wrap}
.hero-cta-hint{margin:8px 0 0;font-size:12px;color:var(--muted);font-weight:500}

/* Hero side */
.hero-side h3{font-size:16px;font-weight:700;color:var(--soft);text-transform:uppercase;letter-spacing:.06em;margin-bottom:20px}
.proof-item{padding:14px 0;border-top:1px solid var(--line)}
.proof-item:first-of-type{padding-top:0;border-top:0}
.proof-item strong{display:block;font-size:15px;margin-bottom:3px;color:var(--text)}
.proof-item span{font-size:14px;color:var(--muted);line-height:1.5}
.hero-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px;padding-top:20px;border-top:1px solid var(--line)}
.tag{padding:5px 12px;border-radius:999px;background:var(--surface-2);border:1px solid var(--line-strong);font-size:12px;font-weight:700;color:var(--text)}

/* ── APP / BUILDER ── */
.app-grid{display:grid;grid-template-columns:1fr 380px;gap:24px;align-items:start}
.builder{padding:36px;box-shadow:var(--shadow-md)}
.builder-head{margin-bottom:32px}
.builder-head .section-eyebrow{margin-bottom:6px}
.builder-head h2{font-size:clamp(22px,2.5vw,30px)}
.section-eyebrow{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;display:block}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:24px}
.section-head p{margin:8px 0 0;font-size:15px;color:var(--muted);max-width:58ch}

.step{padding:28px 0;border-top:1px solid var(--line)}
.step:first-of-type{padding-top:0;border-top:0}
.step-label{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.step-label h3{font-size:16px;font-weight:700}
.step-num{width:28px;height:28px;border-radius:999px;display:grid;place-items:center;background:var(--primary-soft);color:var(--primary);font-weight:800;font-size:12px;flex:0 0 28px}

/* Situace */
.situation-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.situation{border:1px solid var(--line);background:var(--surface);border-radius:14px;padding:16px;cursor:pointer;text-align:left;color:var(--text);display:flex;flex-direction:column;gap:5px;transition:border-color .15s,background .15s}
.situation strong{font-size:14px;font-weight:700}
.situation span{font-size:13px;color:var(--muted)}
.situation:hover{border-color:var(--line-strong)}
.situation.active{border-color:var(--primary);background:var(--primary-soft)}

/* Trade pills */
.trade-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.trade-grid-extra{margin-top:8px}
.trade-pill{padding:9px 8px;border:1px solid var(--line);border-radius:999px;background:var(--surface);font-weight:600;font-size:13px;text-align:center;cursor:pointer;color:var(--text);transition:border-color .15s,background .15s}
.trade-pill:hover{border-color:var(--line-strong)}
.trade-pill.active{background:var(--primary-soft);border-color:var(--primary);color:var(--primary)}
.show-more-btn{margin-top:10px;padding:0;border:0;background:transparent;font-size:13px;font-weight:700;color:var(--primary);cursor:pointer;text-align:left}
.show-more-btn:hover{text-decoration:underline}
.hidden{display:none}

/* Fields */
.field-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.field.full{grid-column:1/-1}
label{display:block;margin-bottom:5px;font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
input,textarea,select{width:100%;padding:11px 14px;border-radius:12px;border:1px solid var(--line);background:var(--surface);color:var(--text);outline:none;font-size:16px;font-family:inherit;letter-spacing:normal}
input::placeholder,textarea::placeholder{color:var(--soft)}
input:focus,textarea:focus,select:focus{border-color:var(--primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--primary) 16%,transparent)}
textarea{min-height:96px;resize:vertical}
.field-divider{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--soft);padding:12px 0 4px;grid-column:1/-1;border-top:1px solid var(--line);margin-top:4px}

/* Accordion */
.accordion{border:1px solid var(--line);border-radius:14px;background:var(--surface)}
.accordion-summary{list-style:none;cursor:pointer;padding:14px 18px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.accordion-summary::-webkit-details-marker{display:none}
.accordion-summary strong{font-size:14px;color:var(--text)}
.accordion-summary small{font-size:12px;color:var(--soft)}
.accordion-body{padding:4px 18px 18px}

/* Buttons */
.cta-row,.actions,.hero-cta,.pricing-cta{display:flex;gap:10px;flex-wrap:wrap}
.primary-btn,.ghost-btn,.small-btn{padding:12px 20px;border-radius:12px;font-weight:700;cursor:pointer;min-height:44px;border:1px solid transparent;display:inline-flex;align-items:center;justify-content:center;font-size:14px;transition:background .15s,border-color .15s}
.primary-btn{background:var(--primary);border-color:var(--primary);color:var(--primary-ink)}
.primary-btn:hover{background:var(--primary-strong)}
.ghost-btn,.small-btn{background:var(--surface);border-color:var(--line);color:var(--text)}
.ghost-btn:hover,.small-btn:hover{border-color:var(--line-strong)}
.small-btn.primary{background:var(--primary-soft);border-color:color-mix(in srgb,var(--primary) 35%,var(--line));color:var(--primary)}

/* CTA row */
.cta-row{margin-top:8px}

/* ── SIDEBAR ── */
.sidebar{position:sticky;top:84px;display:grid;gap:0}
.card{padding:28px}
.card h3{font-size:17px;margin-bottom:16px}
.result-meta{display:grid;gap:6px;margin-bottom:16px}
.result-meta div{padding:8px 12px;border-radius:10px;background:var(--surface-2);border:1px solid var(--line);color:var(--text);display:flex;justify-content:space-between;gap:8px;font-size:13px}
.result-box{padding:18px;border-radius:14px;background:var(--surface-2);border:1px solid var(--line);min-height:200px;white-space:pre-wrap;color:var(--text);font-size:14px;line-height:1.7}
.actions{margin-top:12px}
.upgrade-hint{margin-top:14px;padding:14px 16px;border-radius:14px;background:var(--primary-soft);border:1px solid color-mix(in srgb,var(--primary) 25%,var(--line))}
.upgrade-hint strong{display:block;color:var(--primary);font-size:13px;margin-bottom:3px}
.upgrade-hint span{display:block;color:var(--muted);font-size:12px;line-height:1.5;margin-bottom:7px}
.upgrade-link{font-size:12px;font-weight:700;color:var(--primary);text-decoration:underline;text-underline-offset:2px}

/* ── PDF SEKCE ── */
.pdf-section{padding:8px 0 72px}
.pdf-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:24px;align-items:start}
.pdf-card{padding:40px}
.pdf-card .section-eyebrow{margin-bottom:10px}
.pdf-card h3{font-size:22px;margin:0 0 14px;letter-spacing:-.03em}
.pdf-muted{font-size:15px;color:var(--muted);margin:0 0 16px;line-height:1.6}
.list{margin:0;padding-left:18px}
.list li{margin:7px 0;font-size:14px;color:var(--muted);line-height:1.5}
.list-no{color:var(--muted) !important;text-decoration:line-through;opacity:.75}

.pdf-preview{background:#fff;color:#17201d;border:1px solid #d8e2de;border-radius:22px;box-shadow:0 24px 64px rgba(15,24,20,.13);overflow:hidden}
.pdf-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;padding:20px 24px;border-bottom:1px solid #dce6e2}
.pdf-brand{display:flex;gap:12px;align-items:center}
.pdf-logo{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,#0f766e,#4db8af);display:grid;place-items:center;color:#fff}
.pdf-logo svg{width:22px;height:22px}
.pdf-title strong{display:block;font-size:17px;letter-spacing:-.03em;color:#17201d}
.pdf-title span{color:#52615b;font-size:12px}
.pdf-meta{display:grid;gap:2px;text-align:right;font-size:12px;color:#20302b}
.pdf-body{padding:20px 24px}
.pdf-cols{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}
.pdf-box{padding:12px;border-radius:12px;background:#f5f8f7;border:1px solid #dce6e2;color:#17201d;font-size:12px;line-height:1.6}
.pdf-box strong{display:block;margin-bottom:4px;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:#52615b}
.pdf-table{width:100%;border-collapse:collapse;font-size:12px}
.pdf-table th,.pdf-table td{padding:8px;border-bottom:1px solid #dce6e2;text-align:left;color:#17201d}
.pdf-table th{font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:#52615b}
.pdf-total{display:flex;justify-content:flex-end;margin-top:14px}
.pdf-total-box{min-width:220px;padding:12px;border-radius:14px;background:#f0f7f5;border:1px solid #d5e5e0}
.pdf-total-row{display:flex;justify-content:space-between;padding:3px 0;font-size:13px;color:#17201d}
.pdf-total-row.final{font-size:17px;font-weight:800;color:#0f766e;padding-top:8px;border-top:1px solid #cce0da;margin-top:6px}
.pdf-note{margin-top:12px;padding:10px 12px;border-radius:10px;background:#fafcfc;border:1px dashed #ccddd8;font-size:12px;color:#52615b}

/* ── PRICING ── */
.pricing-section{padding-bottom:88px}
.pricing-note-top{font-size:13px;color:var(--soft);font-weight:500;white-space:nowrap}
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:0}
.pricing-card{padding:28px;border-radius:20px;display:flex;flex-direction:column;gap:6px}
.pricing-pill{display:inline-flex;align-items:center;padding:3px 10px;border-radius:999px;background:var(--surface-2);color:var(--soft);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;margin-bottom:6px}
.pricing-card h3{font-size:22px;letter-spacing:-.03em}
.pricing-price{font-size:30px;font-weight:800;color:var(--text);line-height:1;margin:6px 0 0}
.pricing-per{font-size:15px;font-weight:500;color:var(--muted)}
.pricing-note{font-size:13px;color:var(--soft);margin-top:4px}
.pricing-card .list{margin-top:12px}
.pricing-featured{border-color:var(--primary);box-shadow:var(--shadow-md)}
.pricing-featured::before{content:attr(data-recommended);position:absolute;top:16px;right:18px;padding:3px 9px;border-radius:999px;background:var(--primary-soft);color:var(--primary);font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.08em}

/* Firma karta — odlišení od Free */
.pricing-firm{
  background:linear-gradient(135deg,var(--surface-2) 0%,var(--surface) 100%);
  border-color:var(--line-strong);
}
.pricing-firm .pricing-pill{
  background:var(--primary-soft);
  color:var(--primary);
}
.pricing-card{position:relative}
.pricing-cta{margin-top:auto;padding-top:16px}

/* Error */
.field-error{border-color:#b91c1c !important;box-shadow:0 0 0 2px rgba(185,28,28,.25) !important}

/* Mobile sticky */
.mobile-sticky{display:none}
.mobile-sticky.hidden-by-cookie{display:none!important}

/* ── RESPONSIVE ── */
@media(max-width:1080px){
  .hero-grid,.app-grid,.pdf-grid,.pricing-grid{grid-template-columns:1fr}
  .sidebar{position:static}
  .trade-grid{grid-template-columns:repeat(3,1fr)}
}

/* ── TABLET ── */
@media(max-width:780px){
  .pricing-grid{grid-template-columns:1fr}
  .pdf-grid{grid-template-columns:1fr}
  .pdf-preview{display:none} /* schovat PDF mock na tabletu/mobilu - zbytečně zabírá místo */
  .pdf-card{padding:32px}
}

/* ── MOBIL ── */
@media(max-width:680px){

  /* Topbar */
  .topbar-inner{min-height:56px;gap:6px}
  .top-nav{display:none}
  .theme-btn{width:34px;height:34px;font-size:14px;border-radius:9px}
  .brand span{font-size:17px}
  .logo{width:34px;height:34px;border-radius:10px}
  .logo svg{width:20px;height:20px}
  /* Top-actions kompaktní na mobilu */

  /* ── Lang switch: mobilní dropdown ── */
  .lang-opts{display:none;} /* schováno, přepínáme přes trigger */
  .lang-trigger{display:flex;} /* trigger viditelný na mobilu */

  /* Dropdown panel */
  .lang-switch.lang-open .lang-opts{
    display:flex;
    flex-direction:column;
    position:absolute;
    top:calc(100% + 6px);
    right:0;
    background:var(--surface);
    border:1px solid var(--line);
    border-radius:12px;
    box-shadow:var(--shadow-md);
    padding:4px;
    z-index:200;
    min-width:80px;
    gap:2px;
  }
  .lang-switch.lang-open .lang-opts .lang-btn{
    padding:8px 12px;border-radius:8px;
    font-size:13px;font-weight:600;
    display:flex;gap:8px;align-items:center;
  }
  .lang-switch.lang-open .lang-opts .lang-code{display:inline;}
  .lang-switch.lang-open .lang-opts .flag{font-size:16px;}
  .top-actions{gap:4px}
  /* Login tlačítko v topbaru schováno na mobilu — je i v hamburgeru */
  .top-actions .fb-login-btn{display:none}

  /* Layout */
  .wrap{padding:0 14px}
  .section{padding:36px 0}
  .section-head{flex-direction:column;align-items:flex-start;gap:10px}
  .section-head p{font-size:14px}

  /* Hero */
  .hero{padding:28px 0 20px}
  .hero-grid{gap:12px}
  .hero-copy{padding:20px}
  .hero-side{padding:20px;display:none} /* schovat hero side na mobilu - přebytečné */
  h1{font-size:30px;letter-spacing:-.035em}
  .lead{font-size:15px;margin-bottom:20px}
  .hero-cta{gap:8px}
  .hero-cta .primary-btn,.hero-cta .ghost-btn{flex:1;text-align:center;font-size:13px;padding:11px 14px}
  .hero-tags{gap:6px;margin-top:16px}
  .tag{font-size:11px;padding:4px 10px}

  /* Builder */
  .builder{padding:20px;border-radius:16px}
  .builder-head{margin-bottom:20px}
  .builder-head h2{font-size:20px}
  .step{padding:20px 0}

  /* Situace - 1 sloupec na úzkém mobilu, 2 na širším */
  .situation-grid{grid-template-columns:repeat(2,1fr);gap:8px}
  .situation{padding:12px;border-radius:12px}
  .situation strong{font-size:13px}
  .situation span{font-size:12px}

  /* Trade pills */
  .trade-grid{grid-template-columns:repeat(2,1fr);gap:6px}
  .trade-pill{padding:8px 6px;font-size:12px}

  /* Fields */
  .field-grid{grid-template-columns:1fr;gap:10px}
  .field-grid .field{grid-column:auto}
  .field.full{grid-column:auto}
  input,textarea,select{padding:10px 12px;font-size:14px}
  textarea{min-height:80px}

  /* Accordion */
  .accordion-summary{padding:12px 14px}
  .accordion-body{padding:4px 14px 14px}

  /* Buttons */
  .cta-row{flex-direction:column;gap:8px}
  .cta-row .primary-btn,.cta-row .ghost-btn{width:100%;justify-content:center}
  .actions{display:grid;grid-template-columns:1fr 1fr;gap:6px}
  .small-btn{width:100%;font-size:13px;padding:11px 10px;min-height:44px}

  /* Sidebar / výsledek */
  .card{padding:18px;border-radius:16px}
  .card h3{font-size:15px;margin-bottom:12px}
  .result-meta div{font-size:12px;padding:7px 10px}
  .result-box{padding:14px;min-height:140px;font-size:13px}
  .upgrade-hint{padding:12px 14px}

  /* PDF sekce */
  .pdf-section{padding:8px 0 48px}
  .pdf-card{padding:20px}
  .pdf-card h3{font-size:18px}
  .pdf-muted{font-size:14px}
  .pdf-card .primary-btn{width:100%;justify-content:center}

  /* Pricing */
  .pricing-section{padding-bottom:60px}
  .pricing-card{padding:22px}
  .pricing-price{font-size:26px}
  .billing-toggle{width:100%}
  .billing-btn{flex:1;justify-content:center}

  /* Recenze */
  .reviews-grid{grid-template-columns:1fr;gap:12px}
  .review-card{padding:18px}

  /* Mobile sticky CTA */
  .mobile-sticky{display:block;position:fixed;bottom:0;left:0;right:0;z-index:55;padding:12px 14px;background:color-mix(in srgb,var(--bg) 96%,transparent);backdrop-filter:blur(16px);border-top:1px solid var(--line)}
  .mobile-sticky .primary-btn{width:100%;font-size:15px;padding:14px}
  /* Padding aby sticky nepřekrýval obsah */
  body{padding-bottom:80px}
  /* Pricing CTA full width */
  .pricing-cta .primary-btn,
  .pricing-cta .ghost-btn{width:100%;justify-content:center}
  /* Hero eyebrow — menší text aby se nevlomil */
  .eyebrow{font-size:11px;padding:4px 10px}
}

/* ── VELMI MALÝ MOBIL (< 380px) ── */
@media(max-width:380px){
  .situation-grid{grid-template-columns:1fr}
  .trade-grid{grid-template-columns:repeat(2,1fr)}
  h1{font-size:26px}
  .hero-cta{flex-direction:column}
  .hero-cta .primary-btn,.hero-cta .ghost-btn{width:100%}
}

/* ── LANG SWITCH S VLAJKAMI ── */
.flag{font-size:14px;line-height:1}
.lang-code{font-size:11px;font-weight:700}

/* ── FOOTER ── */
/* ── FAQ ──────────────────────────────────────────────────────────────────── */
.faq-section{padding:80px 0;background:var(--bg)}
.faq-list{display:flex;flex-direction:column;gap:8px;max-width:760px;margin:0 auto}
.faq-item{border:1px solid var(--line);border-radius:16px;background:var(--surface);overflow:hidden;transition:border-color .2s}
.faq-item[open]{border-color:var(--primary)}
.faq-item summary{
  list-style:none;cursor:pointer;
  padding:20px 24px;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  font-size:16px;font-weight:700;color:var(--text);line-height:1.4;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-chevron{width:20px;height:20px;flex-shrink:0;color:var(--muted);transition:transform .25s}
.faq-item[open] .faq-chevron{transform:rotate(180deg);color:var(--primary)}
.faq-body{padding:0 24px 20px;font-size:15px;color:var(--muted);line-height:1.65;border-top:1px solid var(--line)}
.faq-body p{margin:14px 0 0}
.faq-body p:first-child{margin-top:14px}
.faq-body strong{color:var(--text)}
@media(max-width:640px){
  .faq-section{padding:56px 0}
  .faq-item summary{padding:16px 18px;font-size:15px}
  .faq-body{padding:0 18px 16px}
}

.site-footer{border-top:1px solid var(--line);padding:24px 0;margin-top:8px}
.footer-inner{display:flex;flex-direction:column;gap:8px}
.footer-brand{display:flex;align-items:center;gap:8px;font-weight:800;font-size:15px;color:var(--text)}
.footer-meta{font-size:12px;color:var(--soft);line-height:1.6}
.footer-meta a{color:var(--soft);text-decoration:underline;text-underline-offset:2px}
.footer-sep{margin:0 4px}
.footer-links{display:flex;gap:8px;font-size:12px}
.footer-links a{color:var(--primary);text-decoration:underline;text-underline-offset:2px}

/* ── COOKIE LIŠTA ── */
.cookie-bar{position:fixed;bottom:0;left:0;right:0;z-index:100;background:var(--surface);border-top:1px solid var(--line);box-shadow:0 -4px 24px rgba(0,0,0,.08);padding:16px 24px;display:none}
.cookie-bar.visible{display:block}
.cookie-inner{max-width:var(--container);margin:0 auto;display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.cookie-inner p{margin:0;font-size:13px;color:var(--muted);flex:1;min-width:200px}
.cookie-inner a{color:var(--primary);text-decoration:underline}
.cookie-ok{padding:9px 18px;min-height:36px;font-size:13px;white-space:nowrap}

@media(max-width:680px){
  .footer-meta{font-size:11px}
  .footer-sep{display:none}
  .footer-meta{display:flex;flex-direction:column;gap:2px}
  .cookie-inner{flex-direction:column;align-items:flex-start}
  .cookie-ok{width:100%}
}

/* ── BILLING TOGGLE ── */
.billing-toggle{
  display:flex;align-items:center;justify-content:center;
  gap:4px;
  margin:0 auto 36px;
  background:var(--surface-2);
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  padding:4px;
  width:fit-content;
}
.billing-btn{
  padding:9px 20px;
  border:none;border-radius:calc(var(--radius-sm) - 4px);
  background:transparent;
  color:var(--muted);
  font-size:14px;font-weight:600;
  cursor:pointer;
  transition:background .18s,color .18s,box-shadow .18s;
  display:flex;align-items:center;gap:8px;
  white-space:nowrap;
}
.billing-btn.active{
  background:var(--surface);
  color:var(--text);
  box-shadow:var(--shadow-sm);
}
.billing-badge{
  display:inline-block;
  background:var(--primary-soft);
  color:var(--primary);
  font-size:11px;font-weight:700;
  padding:2px 7px;
  border-radius:20px;
  letter-spacing:.01em;
}
[data-billing="yearly"] .price-monthly,
[data-billing="yearly"] .pricing-note-monthly{
  display:none;
}
[data-billing="yearly"] .price-yearly,
[data-billing="yearly"] .pricing-note-yearly{
  display:inline !important;
}

/* ── FREEMIUM MODALS ── */
.fb-modal-overlay{
  position:fixed;inset:0;z-index:1000;
  background:rgba(6,9,9,.72);
  backdrop-filter:blur(6px);
  display:flex;align-items:center;justify-content:center;
  padding:20px;
  opacity:0;transition:opacity .25s ease;
  overflow-y:auto; /* scrollovatelný overlay */
}
.fb-modal-overlay.visible{opacity:1}

.fb-modal{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);
  padding:40px 36px;
  max-width:420px;width:100%;
  text-align:center;
  transform:translateY(16px);transition:transform .25s ease;
  margin:auto; /* správné centrování v scrollovatelném overlaji */
}
.fb-modal-overlay.visible .fb-modal{transform:translateY(0)}

.fb-modal-icon{
  font-size:36px;margin-bottom:16px;
  line-height:1;
}

.fb-modal h2{
  margin:0 0 10px;
  font-size:20px;font-weight:800;
  color:var(--text);
  line-height:1.25;
}

.fb-modal p{
  margin:0 0 20px;
  font-size:15px;color:var(--muted);
  line-height:1.55;
}

.fb-modal input[type="email"],
.fb-modal input[type="text"],
.fb-modal input[type="tel"]{
  width:100%;padding:12px 16px;
  border:1.5px solid var(--line);
  border-radius:var(--radius-sm);
  background:var(--surface-2);
  color:var(--text);
  font-size:16px; /* min 16px = iOS nezoomuje */
  font-family:inherit;
  letter-spacing:normal;
  margin-bottom:8px;
  transition:border-color .15s;
}
/* OTP kód — speciální styl jen pro kód input */
#fb-login-code{
  text-align:center;
  font-size:26px;font-weight:700;
  letter-spacing:10px;
}
.fb-modal input[type="email"]:focus,
.fb-modal input[type="text"]:focus,
.fb-modal input[type="tel"]:focus{
  outline:none;border-color:var(--primary);
}
.fb-modal input[type="email"].field-error,
.fb-modal input[type="text"].field-error{
  border-color:#e53e3e;
  animation:shake .25s ease;
}

.fb-modal-hint{
  font-size:12px !important;
  color:var(--soft) !important;
  margin-bottom:20px !important;
}

.fb-modal-btn{
  display:block;width:100%;
  padding:14px 20px;
  background:var(--primary);color:var(--primary-ink);
  border:none;border-radius:var(--radius-sm);
  font-size:15px;font-weight:700;
  cursor:pointer;
  transition:background .15s,transform .1s;
  margin-bottom:10px;
}
.fb-modal-btn:hover{background:var(--primary-strong);transform:translateY(-1px)}
.fb-modal-btn:active{transform:translateY(0)}

.fb-modal-skip{
  display:block;width:100%;
  background:none;border:none;
  color:var(--soft);font-size:14px;
  cursor:pointer;padding:8px;
  text-decoration:underline;text-underline-offset:3px;
  transition:color .15s;
}
.fb-modal-skip:hover{color:var(--text)}

/* Login button in nav */
.fb-login-btn{
  display:inline-flex;align-items:center;
  padding:6px 14px;
  background:transparent;
  border:1.5px solid var(--primary);
  border-radius:20px;
  color:var(--primary);
  font-size:13px;font-weight:600;
  cursor:pointer;
  white-space:nowrap;
  transition:background .15s,color .15s;
}
.fb-login-btn:hover{background:var(--primary);color:var(--primary-ink)}

/* Onboarding wide modal */
.fb-modal-wide{max-width:560px !important}

.fb-onboard-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;
  margin-bottom:16px;
}
.fb-onboard-grid .field{display:flex;flex-direction:column;gap:4px}
.fb-onboard-grid .field label{font-size:12px;font-weight:600;color:var(--soft)}
.fb-onboard-grid input{
  padding:9px 12px;
  border:1.5px solid var(--line);
  border-radius:10px;
  background:var(--surface-2);
  color:var(--text);
  font-size:16px; /* 16px = iOS nezoomuje */
  font-family:inherit; /* iOS jinak použije monospace */
  letter-spacing:normal;
  transition:border-color .15s;
}
.fb-onboard-grid input:focus{outline:none;border-color:var(--primary)}
.fb-onboard-grid .field[style*="grid-column"]{grid-column:1/-1}

/* VAT sekce */
.fb-vat-section{
  background:var(--surface-2);
  border-radius:12px;padding:14px 16px;
  margin-bottom:16px;
}
.fb-vat-label{
  display:block;font-size:12px;font-weight:600;
  color:var(--soft);margin-bottom:8px;
}
.fb-vat-toggle{
  display:flex;gap:8px;
}
.fb-vat-btn{
  flex:1;padding:8px 10px;
  border:1.5px solid var(--line);
  border-radius:10px;
  background:var(--surface);
  color:var(--muted);
  font-size:13px;font-weight:500;
  cursor:pointer;transition:all .15s;
}
.fb-vat-btn.active{
  border-color:var(--primary);
  background:var(--primary-soft);
  color:var(--primary);font-weight:700;
}
.fb-vat-section input{
  width:100%;padding:9px 12px;
  border:1.5px solid var(--line);
  border-radius:10px;
  background:var(--surface);
  color:var(--text);font-size:14px;
}
.fb-vat-section input:focus{outline:none;border-color:var(--primary)}
.fb-vat-section label{
  display:block;font-size:12px;font-weight:600;
  color:var(--soft);margin-bottom:4px;
}

@media(max-width:480px){
  .fb-onboard-grid{grid-template-columns:1fr}
  .fb-vat-toggle{flex-direction:column}

  /* Modal na malém mobilu — kompaktní, scrollovatelný */
  .fb-modal-overlay{align-items:flex-start;padding:12px}
  .fb-modal{padding:24px 18px;border-radius:16px;margin:0 auto}
  .fb-modal-wide{padding:20px 16px}
  .fb-onboard-grid input{font-size:16px;padding:10px 12px}
  .fb-modal h2{font-size:20px}
  .fb-modal-icon{font-size:28px;margin-bottom:10px}
}

/* Paywall extras */
.fb-paywall-price{
  display:flex;align-items:baseline;justify-content:center;
  margin:8px 0 16px;
}
.fb-price-amount{
  font-size:32px;font-weight:800;color:var(--primary);
}
.fb-price-period{
  font-size:15px;color:var(--muted);
}

.fb-paywall-perks{
  list-style:none;padding:0;margin:0 0 24px;
  text-align:left;
  display:inline-block;
}
.fb-paywall-billing{
  display:flex;gap:8px;justify-content:center;
  margin:0 0 20px;
}
.fb-billing-toggle{
  flex:1;padding:10px 12px;
  border:2px solid var(--line);
  border-radius:10px;
  background:transparent;
  color:var(--text);
  font-size:14px;font-weight:600;
  cursor:pointer;
  transition:border-color .15s,background .15s,color .15s;
}
.fb-billing-toggle.active{
  border-color:var(--primary);
  background:var(--primary);
  color:#fff;
}

.fb-paywall-perks li{
  font-size:14px;color:var(--muted);
  padding:3px 0;
}

/* Loading state on button */
.btn-primary.loading,
button.loading{
  opacity:.7;cursor:not-allowed;
}

@keyframes shake{
  0%,100%{transform:translateX(0)}
  25%{transform:translateX(-6px)}
  75%{transform:translateX(6px)}
}

@media(max-width:480px){
  .fb-modal{padding:28px 20px}
  .fb-modal h2{font-size:18px}
  .fb-price-amount{font-size:26px}
}

/* ── FEEDBACK WIDGET ── */
.feedback-widget{
  margin-top:16px;
  padding:14px 16px;
  background:var(--surface-2);
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
}
.feedback-widget p{
  margin:0 0 10px;
  font-size:13px;color:var(--muted);
}
.feedback-btns{
  display:flex;gap:8px;
}
.fb-vote{
  flex:1;
  padding:8px 10px;
  border:1.5px solid var(--line);
  border-radius:10px;
  background:var(--surface);
  color:var(--muted);
  font-size:18px;
  cursor:pointer;
  transition:border-color .15s,background .15s,transform .1s;
}
.fb-vote:hover{border-color:var(--primary);background:var(--primary-soft);transform:scale(1.05)}
.fb-vote.selected{border-color:var(--primary);background:var(--primary-soft);}
.feedback-comment{
  margin-top:10px;
  display:none;
}
.feedback-comment textarea{
  width:100%;padding:9px 12px;
  border:1.5px solid var(--line);
  border-radius:10px;
  background:var(--surface);
  color:var(--text);
  font-size:13px;
  resize:vertical;min-height:64px;
  transition:border-color .15s;
}
.feedback-comment textarea:focus{outline:none;border-color:var(--primary)}
.feedback-send{
  margin-top:8px;
  padding:8px 16px;
  background:var(--primary);color:var(--primary-ink);
  border:none;border-radius:10px;
  font-size:13px;font-weight:600;
  cursor:pointer;
  transition:background .15s;
}
.feedback-send:hover{background:var(--primary-strong)}
.feedback-thanks{
  font-size:13px;color:var(--primary);
  font-weight:600;display:none;
  margin-top:8px;
}

/* ── RECENZE ── */
.reviews-section{ background:var(--surface-2); }

.reviews-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
  margin-top:40px;
}

.review-card{
  display:flex;flex-direction:column;gap:14px;
  padding:24px;
}

.review-stars{
  color:#f59e0b;
  font-size:15px;
  letter-spacing:1px;
}

.review-text{
  margin:0;
  font-size:15px;line-height:1.6;
  color:var(--text);
  flex:1;
}

.review-author{
  display:flex;align-items:center;gap:12px;
  padding-top:14px;
  border-top:1px solid var(--line);
}

.review-avatar{
  width:38px;height:38px;
  border-radius:50%;
  background:var(--primary);
  color:var(--primary-ink);
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:15px;
  flex-shrink:0;
}

.review-author strong{
  display:block;font-size:14px;font-weight:700;
}
.review-author span{
  font-size:12px;color:var(--soft);
}

@media(max-width:900px){
  .reviews-grid{ grid-template-columns:repeat(2,1fr); }
}
@media(max-width:560px){
  .reviews-grid{ grid-template-columns:1fr; }
}

.reviews-contact{
  margin-top:32px;
  text-align:center;
  font-size:14px;
  color:var(--soft);
}
.reviews-contact a{
  color:var(--primary);
  text-decoration:underline;
  text-underline-offset:3px;
}

/* ── HAMBURGER + MOBILE NAV ── */
.hamburger{
  display:none;
  flex-direction:column;justify-content:center;gap:5px;
  width:36px;height:36px;padding:6px;
  border:1px solid var(--line);border-radius:10px;
  background:var(--surface);cursor:pointer;
  flex-shrink:0;
}
.hamburger span{
  display:block;height:2px;border-radius:2px;
  background:var(--text);
  transition:transform .2s,opacity .2s;
}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mobile-nav{
  display:none;
  position:fixed;top:56px;left:0;right:0;
  max-height:calc(100vh - 56px);
  overflow-y:auto;
  z-index:59;
  background:var(--surface);
  box-shadow:var(--shadow-md);
  flex-direction:column;
  transform:translateY(-8px);
  opacity:0;
  transition:transform .2s ease,opacity .2s ease;
  pointer-events:none;
}
.mobile-nav.open{
  transform:translateY(0);
  opacity:1;
  pointer-events:all;
}
.mobile-nav-link{
  display:block;
  padding:15px 20px;
  font-size:16px;font-weight:600;
  color:var(--text);
  border-bottom:1px solid var(--line);
  text-decoration:none;
  transition:background .15s;
}
.mobile-nav-link:last-child{border-bottom:0}
.mobile-nav-link:active{background:var(--surface-2)}

/* Účet v mobile nav — méně namačkané */
#fb-mobile-account-link{
  display:flex !important;
  align-items:center;
  gap:10px;
  padding:14px 20px !important;
  font-size:14px !important;
  font-weight:700 !important;
  color:var(--primary) !important;
  background:var(--primary-soft);
  border-bottom:1px solid var(--line);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
/* hvězda je součástí textu z main.js — ::before odstraněn */

/* Login tlačítko v mobile nav */
.mobile-nav .fb-login-btn.mobile-nav-link{
  background:none !important;
  border:none !important;
  border-radius:0 !important;
  border-bottom:1px solid var(--line) !important;
  color:var(--primary) !important;
  font-size:16px !important;
  font-weight:600 !important;
  padding:15px 20px !important;
  text-align:left;
  width:100%;
  justify-content:flex-start !important;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  min-height:auto !important;
}

/* Jazyky v mobile nav — sekundární (hlavní jsou v headeru) */
.mobile-nav-langs{
  display:flex;flex-direction:row;gap:0;
  border-top:2px solid var(--line);
  margin-top:auto;
}
.mobile-nav-lang{
  flex:1;
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 10px;
  font-size:14px;font-weight:600;
  color:var(--muted);
  text-decoration:none;
  transition:background .15s,color .15s;
  border-right:1px solid var(--line);
}
.mobile-nav-lang:last-child{border-right:0}
.mobile-nav-lang.active{color:var(--primary);background:var(--primary-soft)}
.mobile-nav-lang:active{background:var(--surface-2)}

/* Kompaktní lang-switch v headeru na mobilu */
.topbar-lang-mobile{
  display:none; /* skryto na desktopu */
}

@media(max-width:680px){
  .hamburger{display:flex}
  .mobile-nav{display:flex}
  .topbar-inner{flex-wrap:nowrap;gap:6px}
  /* Jazyky v headeru na mobilu — jen vlajky */
  .topbar-lang-mobile{
    display:flex;align-items:center;gap:1px;
    flex-shrink:0;
  }
  .topbar-lang-mobile .lang-btn{
    padding:4px 5px;border-radius:7px;gap:0;
  }
  .topbar-lang-mobile .lang-code{display:none}
  .topbar-lang-mobile .flag{font-size:18px}
}
