/* PERSONIQO – shared styles
   Brand: PERSONIQO v4.0
   Pravidla: 60% bílá/neutrální · 30% Brand Dark · 10% Accent (1× focal na sekci)
*/

:root{
  /* Brand */
  --brand-dark:#3A1685;
  --brand-accent:#7855E8;
  --brand-deep:#1F0A4A;
  --brand-soft:#f5f1fc;
  --brand-soft-2:#ece4fa;
  --claim-gray:#5A536B;        /* AA pass na bílém */
  --line:#e7e3f0;
  --white:#FFFFFF;
  --ink:#1F0A4A;
  --ink-soft:#3A1685;
  --gray-300:#9c93b3;          /* dim na bílém – výhradně dekorativní */
  --maxw:1180px;
  --font:"Comfortaa",system-ui,sans-serif;

  /* Spacing scale */
  --pad-xs:8px;
  --pad-s:16px;
  --pad-m:24px;
  --pad-l:40px;
  --pad-xl:88px;

  --radius-s:8px;
  --radius-m:14px;
  --radius-l:24px;

  --shadow-sm:0 6px 18px rgba(31,10,74,.06);
  --shadow-md:0 18px 40px rgba(58,22,133,.08);
  --shadow-lg:0 28px 60px rgba(58,22,133,.18);
}

*{box-sizing:border-box;-webkit-font-smoothing:antialiased}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);font-weight:400;font-size:16px;line-height:1.65;color:var(--ink);background:var(--white);text-rendering:optimizeLegibility}
img,svg{max-width:100%;height:auto;display:block}
a{color:var(--brand-dark);text-decoration:none;transition:color .18s ease}
a:hover{color:var(--brand-accent)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
@media(max-width:600px){.wrap{padding:0 20px}}

/* Skip link */
.skip-link{position:absolute;top:-40px;left:0;background:var(--brand-dark);color:#fff;padding:8px 16px;border-radius:0 0 8px 0;z-index:200;text-decoration:none;font-weight:600}
.skip-link:focus{top:0;color:#fff}

/* Focus states (WCAG 2.4.7) */
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible,summary:focus-visible{outline:2.5px solid var(--brand-accent);outline-offset:3px;border-radius:4px}
.btn:focus-visible{outline-offset:3px;outline-color:var(--brand-accent)}
details:focus-within{outline:none}

/* Sections */
.section{padding:var(--pad-xl) 0}
@media(max-width:720px){.section{padding:56px 0}}
.section--soft{background:var(--brand-soft)}
.section--deep{background:var(--brand-deep);color:#fff}
.section--deep h1,.section--deep h2,.section--deep h3{color:#fff}
.section--deep p{color:#d8d3eb}
.section--deep a{color:#fff;text-decoration:underline}

/* Headings */
h1,h2,h3,h4{font-family:var(--font);color:var(--brand-dark);margin:0 0 18px;letter-spacing:-.005em}
h1{font-weight:700;font-size:clamp(40px,5.6vw,68px);line-height:1.06}
h2{font-weight:700;font-size:clamp(28px,3.4vw,42px);line-height:1.12}
h3{font-weight:600;font-size:20px;line-height:1.3}
h4{font-weight:500;font-size:17px;line-height:1.35;margin-bottom:8px;color:var(--ink)}
p{margin:0 0 14px;max-width:640px}
.lead{font-size:18px;color:var(--claim-gray);font-weight:400;max-width:600px}
.center{text-align:center}
.muted{color:var(--claim-gray)}

/* Eyebrow */
.eyebrow{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--brand-dark);margin-bottom:18px}
.eyebrow--accent{color:var(--brand-accent)}
.eyebrow--inverse{color:#9b6dff}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--font);font-weight:600;font-size:15px;padding:14px 26px;border-radius:var(--radius-s);border:0;cursor:pointer;transition:all .18s ease;text-decoration:none;letter-spacing:.01em;line-height:1}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn--primary{background:var(--brand-dark);color:#fff}
.btn--primary:hover{background:var(--brand-accent);color:#fff;box-shadow:0 10px 30px rgba(120,85,232,.28)}
.btn--outline{background:transparent;color:var(--brand-dark);border:1.5px solid var(--brand-dark)}
.btn--outline:hover{background:var(--brand-dark);color:#fff}
.btn--ghost{background:transparent;color:var(--brand-dark);padding:14px 8px}
.btn--ghost:hover{color:var(--brand-accent);background:transparent;transform:none}
.btn--inverse{background:#fff;color:var(--brand-dark)}
.btn--inverse:hover{background:var(--brand-accent);color:#fff}

/* Hexagon bullet utility */
.hex-bullet{display:inline-block;width:10px;height:11px;background:var(--brand-dark);clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);margin-right:8px;vertical-align:-1px;flex:0 0 10px}
.hex-bullet--accent{background:var(--brand-accent)}

/* Hex frame utility (avatar / icon tile) */
.hex-tile{width:48px;height:54px;background:var(--brand-soft);clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);display:flex;align-items:center;justify-content:center;flex:0 0 48px}
.hex-tile svg{width:24px;height:auto}
.hex-tile--accent{background:var(--brand-soft-2)}

/* Tag pill */
.tag-soft{display:inline-flex;align-items:center;gap:8px;background:var(--brand-soft);color:var(--brand-dark);padding:6px 14px;border-radius:999px;font-size:13px;font-weight:500}

/* Header / nav */
.nav{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.96);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav__inner{display:flex;align-items:center;justify-content:space-between;padding:22px 32px;max-width:var(--maxw);margin:0 auto;gap:24px}
.nav__brand{display:inline-flex;align-items:center;padding:2px 6px;border-radius:4px}
.nav__brand img{height:46px;width:auto}
@media(max-width:600px){.nav__brand img{height:38px}}
.nav__links{display:flex;gap:30px;align-items:center}
.nav__links > a:not(.btn){font-weight:500;color:var(--ink);font-size:15px;padding:6px 0;position:relative}
.nav__links > a:not(.btn)[aria-current="page"]{color:var(--brand-dark);font-weight:600}
.nav__links > a:not(.btn)[aria-current="page"]::after{content:"";position:absolute;left:0;right:0;bottom:-4px;height:2px;background:var(--brand-dark);border-radius:2px}
.nav__links > a:not(.btn):hover{color:var(--brand-accent)}
.nav__cta{margin-left:8px;color:#fff !important}
.nav__cta:hover{color:#fff !important}
.menu-toggle{display:none;background:transparent;border:1.5px solid var(--brand-dark);border-radius:8px;color:var(--brand-dark);padding:8px 10px;font-size:18px;cursor:pointer;line-height:1}
.menu-toggle svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round}
@media(max-width:960px){
  .nav__inner{padding:18px 24px}
  .nav__links{display:none;position:absolute;top:74px;left:0;right:0;background:#fff;flex-direction:column;align-items:stretch;padding:18px 24px;border-bottom:1px solid var(--line);gap:8px;box-shadow:var(--shadow-md)}
  .nav__links.open{display:flex}
  .nav__links a{padding:12px 0;border-bottom:1px solid var(--line)}
  .nav__links a:last-of-type{border-bottom:0}
  .nav__cta{margin:8px 0 4px}
  .menu-toggle{display:inline-flex;align-items:center;justify-content:center}
}

/* Hero */
.hero{position:relative;padding:96px 0 80px;overflow:hidden;background:
  radial-gradient(circle at 12% 18%, var(--brand-soft) 0%, transparent 38%),
  radial-gradient(circle at 88% 86%, var(--brand-soft-2) 0%, transparent 38%),
  #fff
}
.hero__grid{display:grid;grid-template-columns:1.15fr .85fr;gap:60px;align-items:center}
@media(max-width:980px){.hero__grid{grid-template-columns:1fr;gap:40px}.hero{padding:64px 0 60px}}
.hero h1 .ac,h2 .ac,h3 .ac{color:var(--brand-accent)}
/* .ac na bílém pozadí — accent fialová; na tmavém pozadí (.section--deep) světlejší varianta */
.section--deep h2 .ac{color:#b8a3ff}
.hero__wordmark{margin-bottom:22px;max-width:340px}
.hero__wordmark img{width:100%;height:auto;filter:drop-shadow(0 8px 18px rgba(58,22,133,.12))}
@media(max-width:980px){.hero__wordmark{max-width:280px;margin-left:auto;margin-right:auto}}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:14px}
.hero__reassure{display:flex;flex-wrap:wrap;gap:18px;margin-top:28px;color:var(--claim-gray);font-size:14px;font-weight:500}
.hero__reassure span{display:inline-flex;align-items:center}

/* Hero cenový teaser */
.hero__price-teaser{
  display:inline-flex;align-items:baseline;flex-wrap:wrap;gap:6px 10px;
  margin:20px 0 8px;padding:10px 16px;
  background:var(--brand-soft);border-radius:999px;
  font-family:var(--font);
}
.hero__price-from{font-size:13px;font-weight:600;color:var(--claim-gray);letter-spacing:.04em;text-transform:uppercase}
.hero__price-big{font-size:24px;font-weight:700;color:var(--brand-dark);line-height:1}
.hero__price-unit{font-size:14px;font-weight:500;color:var(--claim-gray)}
.hero__price-sep{color:var(--line);font-weight:400}
.hero__price-note{font-size:13px;font-weight:600;color:var(--brand-accent);letter-spacing:.02em}
@media(max-width:520px){
  .hero__price-teaser{padding:8px 14px;gap:4px 8px}
  .hero__price-big{font-size:20px}
}
.trust-bar{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin-top:34px;padding:14px 18px;background:var(--brand-soft);border:1px solid var(--line);border-radius:10px;font-size:13px;color:var(--claim-gray)}
.trust-bar__item strong{color:var(--brand-dark);font-weight:700}
.trust-bar__sep{color:var(--gray-300)}
@media(max-width:520px){.trust-bar{flex-direction:column;align-items:flex-start;gap:6px}.trust-bar__sep{display:none}}

/* Hex art (hero brand mark) */
.hex-art{position:relative;display:flex;align-items:center;justify-content:center;aspect-ratio:1/1;max-width:480px;margin:0 auto;width:100%}
.hex-art__bg{position:absolute;inset:0;opacity:.6;pointer-events:none}
.hex-art__bg svg{width:100%;height:100%}
.hex-art__main{position:relative;width:62%;z-index:1;filter:drop-shadow(0 28px 60px rgba(58,22,133,.22))}

/* Hexík – maskot rodiny v hero (POZOR: nepřebarvovat ho! styly se týkají jen rámu) */
.hexik-stage{position:relative;width:78%;aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;z-index:1}
.hexik-stage__frame{position:absolute;inset:0;clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);background:linear-gradient(135deg,var(--brand-accent),var(--brand-dark));box-shadow:0 36px 80px rgba(58,22,133,.22)}
.hexik-stage__frame::after{content:"";position:absolute;inset:10px;clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);background:#fff}
.hexik-stage__img{position:relative;width:70%;height:auto;filter:none !important}
.speech-bubble{position:absolute;top:8%;right:-6%;background:#fff;border-radius:18px;padding:10px 16px;font-size:14px;font-weight:500;color:var(--brand-dark);box-shadow:0 12px 28px rgba(58,22,133,.16);transform:rotate(2deg);max-width:200px;z-index:2;border:1px solid var(--brand-soft-2)}
.speech-bubble::after{content:"";position:absolute;left:-10px;top:22px;width:0;height:0;border:10px solid transparent;border-right-color:#fff}
@media(max-width:520px){.speech-bubble{font-size:13px;padding:8px 14px}}

/* Mockup browser frame pro screenshoty z aplikace */
.mockup{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:0 28px 70px rgba(58,22,133,.12);max-width:1080px;margin:0 auto}
.mockup__bar{display:flex;align-items:center;gap:6px;padding:10px 14px;background:var(--brand-soft);border-bottom:1px solid var(--line)}
.mockup__dot{width:10px;height:10px;border-radius:50%;background:var(--gray-300)}
.mockup__dot:nth-child(2){background:#d8c8f5}
.mockup__dot:nth-child(3){background:var(--brand-accent);opacity:.5}
.mockup__url{margin-left:14px;font-size:13px;color:var(--claim-gray);background:#fff;padding:4px 12px;border-radius:6px;border:1px solid var(--line)}
.mockup__body{aspect-ratio:16/10;background:linear-gradient(135deg,var(--brand-soft) 0%,var(--brand-soft-2) 100%);display:flex;align-items:center;justify-content:center;color:var(--brand-dark);font-weight:600;font-size:15px;text-align:center;padding:0;position:relative;overflow:hidden;cursor:zoom-in;text-decoration:none}
.mockup__body img,
.mockup__body picture{width:100%;height:100%;display:block}
.mockup__body img{object-fit:cover;object-position:top center}
.mockup__body::after{
  content:"";position:absolute;inset:0;
  background:rgba(58,22,133,0);transition:background .25s ease;
  pointer-events:none;
}
.mockup__body::before{
  content:"";position:absolute;top:14px;right:14px;
  width:36px;height:36px;border-radius:50%;
  background:rgba(255,255,255,.9);
  background-image:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" fill="none" stroke="%233A1685" stroke-width="2.5" stroke-linecap="round"><circle cx="11" cy="11" r="7"/><path d="m21 21-4-4"/><path d="M11 8v6M8 11h6"/></svg>');
  background-repeat:no-repeat;background-position:center;
  opacity:0;transition:opacity .25s ease,transform .25s ease;
  box-shadow:0 4px 12px rgba(31,10,74,.25);
  pointer-events:none;z-index:2;
}
.mockup:hover .mockup__body::after{background:rgba(58,22,133,.08)}
.mockup:hover .mockup__body::before{opacity:1;transform:scale(1.1)}

/* === Lightbox modal === */
.lightbox{
  position:fixed;inset:0;
  background:rgba(15,5,30,.92);
  display:flex;align-items:center;justify-content:center;padding:24px;
  opacity:0;visibility:hidden;
  transition:opacity .25s ease;
  z-index:9999;
}
.lightbox.is-open{opacity:1;visibility:visible}
.lightbox__fig{
  margin:0;max-width:95vw;max-height:90vh;
  display:flex;flex-direction:column;gap:14px;
}
.lightbox__img{
  display:block;max-width:100%;max-height:80vh;
  border-radius:10px;box-shadow:0 28px 60px rgba(0,0,0,.5);
  background:#fff;
}
.lightbox__caption{
  text-align:center;color:#fff;font-size:14px;letter-spacing:.04em;
  opacity:.85;
}
.lightbox__close{
  position:absolute;top:18px;right:18px;
  width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,.12);color:#fff;border:0;
  font-size:28px;line-height:1;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s ease,transform .2s ease;
}
.lightbox__close:hover{background:rgba(255,255,255,.22);transform:scale(1.08)}
.lightbox__close:focus-visible{outline:2.5px solid var(--brand-accent);outline-offset:3px}
@media(prefers-reduced-motion:reduce){.lightbox{transition:none}.mockup__body::before,.mockup__body::after{transition:none}}
.mockup figcaption{
  background:#fff;padding:10px 18px;
  font-size:13px;font-weight:600;color:var(--brand-dark);letter-spacing:.02em;
  text-align:center;border-top:1px solid var(--line);
}
.mockup__body::before{content:"";position:absolute;inset:0;background-image:
  linear-gradient(135deg,transparent 40%,rgba(120,85,232,.06) 50%,transparent 60%),
  repeating-linear-gradient(0deg,transparent,transparent 39px,rgba(58,22,133,.04) 40px);pointer-events:none}
.mockup__placeholder{position:relative;z-index:1;background:rgba(255,255,255,.8);padding:14px 22px;border-radius:10px;border:1px dashed var(--brand-dark)}
.mockup__placeholder small{display:block;font-size:12px;font-weight:400;color:var(--claim-gray);margin-top:4px}

/* Screenshot trio (3 mockupy vedle sebe) */
.screens{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:36px}
@media(max-width:900px){.screens{grid-template-columns:1fr;max-width:520px;margin-left:auto;margin-right:auto}}

/* Q-COM brand block (na o-nas.html) */
.qcom-brand{background:#fff;border:1px solid var(--line);border-radius:18px;padding:40px;display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:40px;margin-top:32px}
@media(max-width:720px){.qcom-brand{grid-template-columns:1fr;padding:28px;gap:28px}}
.qcom-brand__logo{display:flex;align-items:center;justify-content:center}
.qcom-brand__logo img{max-width:340px;height:auto;width:100%}
.qcom-brand__claim{color:var(--claim-gray);font-size:15px;margin:0 0 4px}
.qcom-brand__claim--quote{font-family:var(--font);font-style:italic;color:#0039a6;font-size:22px;line-height:1.4;margin:0;font-weight:500}
.qcom-brand__slogan{max-width:360px;width:100%;height:auto;display:block;border-radius:8px}

/* Q-COM v číslech — 3 columns at proof grid (O nás) */
@media(min-width:821px){.section--deep .proof-grid{grid-template-columns:repeat(3,1fr) !important}}
.section--deep .proof__big{font-size:clamp(24px,3vw,38px)}

/* Product logos in area heads */
.product-logo{margin-bottom:14px;display:flex;align-items:center;min-height:56px}
.product-logo img{max-height:56px;width:auto;max-width:220px;display:block;object-fit:contain}

/* PERSONIQO hero logo block (funkce.html) */
.logo-hero{display:flex;justify-content:center;margin:0 auto 32px;max-width:520px}
.logo-hero img{width:100%;height:auto;filter:drop-shadow(0 18px 40px rgba(58,22,133,.18))}

/* ====== KONTAKT PAGE — Q-COM card ====== */
.qcom-card{
  background:linear-gradient(135deg,var(--brand-deep) 0%,var(--brand-dark) 60%,#4a23a3 100%);
  color:#fff;
  border-radius:var(--radius-l);
  padding:56px;
  margin-top:32px;
  position:relative;
  overflow:hidden;
  box-shadow:0 28px 60px rgba(31,10,74,.25);
}
.qcom-card::before{
  content:"";position:absolute;right:-90px;top:-90px;
  width:320px;height:320px;
  background:rgba(255,255,255,.05);
  clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);
  pointer-events:none;
}
.qcom-card::after{
  content:"";position:absolute;left:-70px;bottom:-110px;
  width:240px;height:240px;
  background:rgba(120,85,232,.22);
  clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);
  pointer-events:none;
}
.qcom-card > *{position:relative;z-index:1}
.qcom-card__head{
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:28px;
  margin-bottom:44px;padding-bottom:28px;
  border-bottom:1px solid rgba(255,255,255,.14);
}
.qcom-card__brand img{
  height:88px;width:auto;display:block;
  filter:brightness(0) invert(1);opacity:.95;
}
.qcom-card__slogan{
  font-style:italic;font-size:20px;font-weight:500;line-height:1.4;
  color:rgba(255,255,255,.88);margin:0;max-width:340px;text-align:right;
}
.qcom-card__channels{
  display:grid;grid-template-columns:repeat(3,1fr);gap:36px;
}
.channel{display:flex;flex-direction:column;gap:8px}
.channel__label{
  font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.6);
}
.channel__big{
  font-family:var(--font);font-weight:600;
  font-size:clamp(20px,2vw,26px);line-height:1.25;color:#fff;
  margin:2px 0 6px;
}
.channel__big a{
  color:#fff;border-bottom:2px solid rgba(255,255,255,.28);
  transition:border-color .2s,color .2s;padding-bottom:2px;
}
.channel__big a:hover{color:#fff;border-bottom-color:var(--brand-accent)}
.channel__sub{font-size:14px;color:rgba(255,255,255,.72);line-height:1.55}
.channel__sub a{color:rgba(255,255,255,.92);text-decoration:underline;text-decoration-color:rgba(255,255,255,.25);text-underline-offset:3px}
.channel__sub a:hover{color:#fff;text-decoration-color:var(--brand-accent)}
.qcom-card__meta{
  display:flex;flex-wrap:wrap;gap:8px 28px;
  margin-top:40px;padding-top:24px;
  border-top:1px solid rgba(255,255,255,.14);
  font-size:13px;color:rgba(255,255,255,.65);
}
.qcom-card__meta strong{color:rgba(255,255,255,.95);font-weight:600}
.qcom-card__meta a{color:rgba(255,255,255,.85);text-decoration:underline;text-decoration-color:rgba(255,255,255,.3);text-underline-offset:3px}
.qcom-card__meta a:hover{color:#fff;text-decoration-color:var(--brand-accent)}
@media(max-width:900px){
  .qcom-card{padding:36px 28px}
  .qcom-card__head{margin-bottom:32px;padding-bottom:22px}
  .qcom-card__brand img{height:64px}
  .qcom-card__slogan{font-size:17px;text-align:left;max-width:none}
  .qcom-card__channels{grid-template-columns:1fr;gap:28px}
  .qcom-card__meta{margin-top:28px;gap:6px 20px}
}

/* What-cards (Demo/Ceník/Pilot) */
.what-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:36px}
@media(max-width:820px){.what-cards{grid-template-columns:1fr}}
.what-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-m);
  padding:28px;display:flex;flex-direction:column;gap:16px;
  transition:transform .25s ease,border-color .2s ease,box-shadow .25s ease;
  position:relative;overflow:hidden;
}
.what-card:hover{
  transform:translateY(-4px);border-color:var(--brand-dark);
  box-shadow:0 16px 36px rgba(31,10,74,.10);
}
.what-card__head{display:flex;align-items:center;gap:14px}
.what-card h3{margin:0;font-size:20px;color:var(--brand-dark)}
.what-card p{margin:0;color:var(--claim-gray);font-size:14.5px;line-height:1.6;flex:1}
.what-card__cta{align-self:flex-start;margin-top:4px}
.what-card--accent{border-color:var(--brand-accent);background:linear-gradient(180deg,#fff 60%,var(--brand-soft) 100%)}
.what-card--accent::before{
  content:"Doporučujeme";
  position:absolute;top:14px;right:14px;
  font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:#fff;background:var(--brand-accent);
  padding:5px 10px;border-radius:999px;
}

/* Trust list (sidebar pod formulářem) */
.trust-list{list-style:none;padding:0;margin:24px 0 0;display:grid;gap:14px;max-width:520px}
.trust-list li{display:flex;gap:12px;align-items:flex-start;color:var(--ink);font-size:15px;line-height:1.55}
.trust-list .hex-bullet{margin-top:7px;flex:0 0 auto}

/* První sekce nahrazující page-hero (když není hero) — přidat top padding pro breadcrumb */
.section--first{padding-top:48px}
.section--first .breadcrumb{margin-bottom:24px}

/* === Logo karuselový marquee === */
.logo-marquee{
  position:relative;overflow:hidden;
  margin-top:36px;padding:24px 0;
  --marquee-duration:35s;
}
.logo-marquee__track{
  display:flex;gap:64px;width:max-content;
  animation:marquee var(--marquee-duration) linear infinite;
  align-items:center;
}
.logo-marquee__item{
  flex:0 0 auto;width:200px;
  display:flex;align-items:center;justify-content:center;
}
.logo-marquee__item img{
  width:100%;height:auto;max-height:90px;display:block;object-fit:contain;
}
@keyframes marquee{
  from{transform:translateX(0)}
  to{transform:translateX(calc(-50% - 32px))}
}
.logo-marquee:hover .logo-marquee__track{animation-play-state:paused}

/* Mini varianta na index — menší loga */
.logo-marquee--mini{padding:8px 0;margin-top:14px;--marquee-duration:42s}
.logo-marquee--mini .logo-marquee__item{width:160px}
.logo-marquee--mini .logo-marquee__item img{max-height:64px}
@media(max-width:720px){
  .logo-marquee--mini .logo-marquee__item{width:120px}
  .logo-marquee--mini .logo-marquee__item img{max-height:48px}
}

/* Grayscale varianta — loga šedá s plnou barvou na hover */
.logo-marquee--grayscale .logo-marquee__item img{
  filter:grayscale(100%);opacity:.55;
  transition:filter .35s ease,opacity .35s ease;
}
.logo-marquee--grayscale .logo-marquee__item:hover img{
  filter:grayscale(0%);opacity:1;
}

/* === Pilot 2026 — karta s urgencí === */
.pilot-card{
  background:linear-gradient(135deg,var(--brand-deep) 0%,var(--brand-dark) 35%,#4a23a3 65%,var(--brand-deep) 100%);
  background-size:300% 300%;
  animation:pilot-gradient 14s ease-in-out infinite;
  color:#fff;border-radius:var(--radius-l);overflow:hidden;position:relative;
  box-shadow:0 24px 60px rgba(31,10,74,.22);
  margin-top:24px;
}
@keyframes pilot-gradient{
  0%   {background-position:0% 50%}
  50%  {background-position:100% 50%}
  100% {background-position:0% 50%}
}
@media (prefers-reduced-motion: reduce){
  .pilot-card{animation:none}
}
.pilot-card::before{
  content:"";position:absolute;right:-90px;top:-90px;
  width:320px;height:320px;
  background:rgba(255,255,255,.05);
  clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);
  pointer-events:none;
}
.pilot-card__badge{
  display:flex;align-items:center;justify-content:center;gap:10px;
  background:rgba(0,0,0,.25);padding:10px 16px;
  font-size:13px;font-weight:600;letter-spacing:.04em;color:#fff;
  border-bottom:1px solid rgba(255,255,255,.1);
  position:relative;z-index:1;
}
.pilot-card__badge-dot{
  width:9px;height:9px;border-radius:50%;background:#ff5a5a;
  box-shadow:0 0 0 0 rgba(255,90,90,.7);
  animation:pulse-dot 2s ease-out infinite;
}
@keyframes pulse-dot{
  0%{box-shadow:0 0 0 0 rgba(255,90,90,.7)}
  70%{box-shadow:0 0 0 12px rgba(255,90,90,0)}
  100%{box-shadow:0 0 0 0 rgba(255,90,90,0)}
}
@media(prefers-reduced-motion:reduce){.pilot-card__badge-dot{animation:none}}
.pilot-card__body{
  display:grid;grid-template-columns:1.4fr 1fr;gap:40px;
  padding:44px 40px;position:relative;z-index:1;
}
@media(max-width:900px){
  .pilot-card__body{grid-template-columns:1fr;gap:32px;padding:32px 24px}
}
.pilot-card__left h2{color:#fff;margin:8px 0 16px;font-size:clamp(28px,3.4vw,42px);line-height:1.1}
.pilot-card__left h2 .ac{color:#ffc857}
.pilot-card .eyebrow--accent{color:#ffc857;background:rgba(255,200,87,.12)}
.pilot-card__lead{font-size:16.5px;line-height:1.6;color:rgba(255,255,255,.82);margin:0 0 22px;max-width:560px}
.pilot-card__benefits{list-style:none;padding:0;margin:0 0 28px;display:grid;gap:12px}
.pilot-card__benefits li{display:flex;gap:12px;align-items:flex-start;color:rgba(255,255,255,.92);font-size:15px;line-height:1.55}
.pilot-card__benefits .hex-bullet{margin-top:6px;flex:0 0 auto;background:#ffc857}
.pilot-card__benefits strong{color:#fff;font-weight:600}
.pilot-card__cta-wrap{margin:0;display:flex;flex-wrap:wrap;gap:12px}
.pilot-card__cta-wrap .btn--primary{background:#ffc857;color:var(--brand-deep);border-color:#ffc857}
.pilot-card__cta-wrap .btn--primary:hover{background:#ffd97a;border-color:#ffd97a;color:var(--brand-deep)}
.pilot-card__cta-wrap .btn--ghost{color:#fff;border-color:rgba(255,255,255,.3)}
.pilot-card__cta-wrap .btn--ghost:hover{border-color:#fff;background:rgba(255,255,255,.06);color:#fff}

/* Pravý sloupec — úspora a urgency */
.pilot-card__right{
  background:rgba(0,0,0,.18);border-radius:var(--radius-m);
  padding:32px 28px;display:flex;flex-direction:column;align-items:center;text-align:center;
  border:1px solid rgba(255,255,255,.08);
}
.pilot-card__save-label{
  font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(255,255,255,.6);
}
.pilot-card__save-big{
  font-family:var(--font);font-weight:700;
  font-size:clamp(40px,4.8vw,56px);line-height:1.05;color:#ffc857;
  margin:12px 0 8px;
}
.pilot-card__save-rows{
  display:flex;flex-direction:column;gap:6px;margin:14px 0 10px;width:100%;
}
.pilot-card__save-row{
  display:flex;justify-content:space-between;align-items:baseline;
  padding:6px 12px;border-radius:8px;
  background:rgba(255,255,255,.04);
}
.pilot-card__save-row--big{background:rgba(255,200,87,.12);border:1px solid rgba(255,200,87,.25)}
.pilot-card__save-tier{
  font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(255,255,255,.7);
}
.pilot-card__save-row--big .pilot-card__save-tier{color:#ffc857}
.pilot-card__save-amount{
  font-family:var(--font);font-weight:700;font-size:20px;color:#fff;
}
.pilot-card__save-row--big .pilot-card__save-amount{font-size:26px;color:#ffc857}
.pilot-card__save-note{font-size:13px;color:rgba(255,255,255,.6);line-height:1.5;max-width:240px}
.pilot-card__divider{
  width:60px;height:2px;background:rgba(255,255,255,.15);margin:24px 0;
}
.pilot-card__urgency{
  font-size:14px;color:rgba(255,255,255,.85);line-height:1.5;
}
.pilot-card__urgency strong{
  display:block;font-family:var(--font);font-size:32px;font-weight:700;color:#fff;line-height:1;
}
.pilot-card__urgency small{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.5)}

/* === SLA matrix tabulka (enterprise.html) === */
.sla-table{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-m);overflow:hidden;
}
.sla-row{
  display:grid;grid-template-columns:1.2fr 2fr 1fr 1.2fr;gap:16px;
  padding:14px 20px;border-bottom:1px solid var(--line);
  font-size:14.5px;line-height:1.5;color:var(--ink);
}
.sla-row:last-child{border-bottom:0}
.sla-row--head{
  background:var(--brand-soft);font-weight:700;font-size:12px;
  letter-spacing:.14em;text-transform:uppercase;color:var(--brand-dark);
}
.sla-row strong{color:var(--brand-dark)}
@media(max-width:820px){
  .sla-row{grid-template-columns:1fr;gap:6px;padding:14px 18px}
  .sla-row--head{display:none}
  .sla-row > div::before{
    content:attr(data-label);display:block;font-size:11px;font-weight:700;
    letter-spacing:.14em;text-transform:uppercase;color:var(--claim-gray);
  }
}

/* === Enterprise pricing 3-col === */
.enterprise-pricing{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
@media(max-width:820px){.enterprise-pricing{grid-template-columns:1fr;gap:18px}}
.enterprise-pricing__col{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-m);
  padding:28px 24px;text-align:center;
}
.enterprise-pricing__label{
  font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--claim-gray);
}
.enterprise-pricing__amount{
  font-family:var(--font);font-weight:700;font-size:clamp(22px,2.4vw,30px);
  color:var(--brand-dark);margin:10px 0 6px;line-height:1.1;
}
.enterprise-pricing__note{font-size:13px;color:var(--claim-gray);line-height:1.5}

/* === Page hero enterprise variant === */
.page-hero--enterprise{
  background:linear-gradient(135deg,var(--brand-soft) 0%,#fff 60%);
}

/* === ROI Calculator (cenik.html) === */
.roi-calc{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-l);
  padding:40px;margin-top:48px;
  box-shadow:0 16px 40px rgba(31,10,74,.06);
}
@media(max-width:720px){.roi-calc{padding:28px 22px}}
.roi-calc__head{text-align:center;margin-bottom:24px}
.roi-calc__head h2{margin:8px 0 0;font-size:clamp(22px,2.4vw,30px)}
.roi-calc__slider-wrap{
  margin:32px auto 28px;max-width:680px;
}
.roi-calc__slider-label{
  display:flex;justify-content:space-between;align-items:baseline;
  margin-bottom:12px;
}
.roi-calc__slider-label span:first-child{
  font-size:13px;font-weight:600;letter-spacing:.04em;color:var(--claim-gray);
}
.roi-calc__slider-value{
  font-family:var(--font);font-weight:700;font-size:32px;color:var(--brand-dark);
}
.roi-calc__slider-value small{
  font-size:14px;font-weight:500;color:var(--claim-gray);margin-left:8px;
}
input[type="range"].roi-calc__slider{
  -webkit-appearance:none;appearance:none;
  width:100%;height:6px;background:var(--brand-soft);border-radius:999px;
  outline:none;cursor:pointer;
}
input[type="range"].roi-calc__slider::-webkit-slider-thumb{
  -webkit-appearance:none;width:24px;height:24px;
  background:var(--brand-dark);border-radius:50%;border:3px solid #fff;
  box-shadow:0 4px 12px rgba(58,22,133,.25);transition:transform .15s;
}
input[type="range"].roi-calc__slider::-webkit-slider-thumb:hover{transform:scale(1.15)}
input[type="range"].roi-calc__slider::-moz-range-thumb{
  width:24px;height:24px;background:var(--brand-dark);border-radius:50%;border:3px solid #fff;
  box-shadow:0 4px 12px rgba(58,22,133,.25);cursor:pointer;
}
.roi-calc__ticks{
  display:flex;justify-content:space-between;margin-top:10px;
  font-size:11px;color:var(--claim-gray);font-weight:500;letter-spacing:.04em;
}
.roi-calc__ticks span:first-child{text-align:left}
.roi-calc__ticks span:nth-child(2){flex:1;text-align:center}
.roi-calc__ticks span:last-child{text-align:right}
.roi-calc__tier-info{text-align:center !important}
.roi-calc .footnote,
.roi-calc__footnote{
  text-align:center !important;
  margin:18px auto 0 !important;
  max-width:560px;
}
.roi-calc__results{
  display:grid;grid-template-columns:1fr 1fr 1.2fr;gap:18px;margin-top:32px;
}
@media(max-width:720px){.roi-calc__results{grid-template-columns:1fr;gap:14px}}
.roi-calc__result{
  background:var(--brand-soft);border-radius:var(--radius-m);padding:22px 20px;
  text-align:center;border:1px solid transparent;
}
.roi-calc__result--us{
  background:linear-gradient(135deg,var(--brand-deep),var(--brand-dark));color:#fff;
}
.roi-calc__result--save{
  background:#fff;border-color:var(--brand-accent);
  box-shadow:0 8px 24px rgba(120,85,232,.15);
}
.roi-calc__result-label{
  font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--claim-gray);margin-bottom:8px;
}
.roi-calc__result--us .roi-calc__result-label{color:rgba(255,255,255,.7)}
.roi-calc__result-big{
  font-family:var(--font);font-weight:700;font-size:clamp(22px,2.6vw,30px);
  line-height:1.1;color:var(--brand-dark);
}
.roi-calc__result--us .roi-calc__result-big{color:#fff}
.roi-calc__result--save .roi-calc__result-big{color:var(--brand-accent);font-size:clamp(26px,3vw,36px)}
.roi-calc__result-sub{font-size:13px;color:var(--claim-gray);margin-top:4px}
.roi-calc__result--us .roi-calc__result-sub{color:rgba(255,255,255,.7)}
.roi-calc__tier-info{
  margin-top:20px;text-align:center;font-size:13px;color:var(--claim-gray);
}
.roi-calc__tier-info strong{color:var(--brand-dark);font-weight:600}
.roi-calc__cta{margin-top:24px;text-align:center}

/* Logo strip sekce na index */
.section--logos{padding:40px 0;background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
@media(max-width:720px){.section--logos{padding:28px 0}}
.logo-strip__caption{
  text-align:left;margin:0 0 12px;
  font-size:13px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  color:var(--claim-gray);
}
/* Fade okraje */
.logo-marquee::before,
.logo-marquee::after{
  content:"";position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none;
}
.logo-marquee::before{left:0;background:linear-gradient(90deg,#fff 0%,rgba(255,255,255,0) 100%)}
.logo-marquee::after{right:0;background:linear-gradient(270deg,#fff 0%,rgba(255,255,255,0) 100%)}
@media(max-width:720px){
  .logo-marquee__item{width:150px}
  .logo-marquee__item img{max-height:64px}
  .logo-marquee__track{gap:40px}
  .logo-marquee{--marquee-duration:28s}
  .logo-marquee::before,.logo-marquee::after{width:40px}
}
@media (prefers-reduced-motion: reduce){
  .logo-marquee__track{animation:none;flex-wrap:wrap;width:auto;justify-content:center;gap:32px 48px}
  .logo-marquee::before,.logo-marquee::after{display:none}
}

/* === Story blocks (Před PERSONIQO / Po nasazení) === */
.story-block{margin-top:22px;padding-top:22px;border-top:1px dashed var(--line)}
.story-block:first-of-type{margin-top:16px;padding-top:0;border-top:0}
.story-block__label{
  display:inline-block;margin:0 0 12px;
  font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  padding:6px 12px;border-radius:6px;
}
.story-block--before .story-block__label{
  color:var(--claim-gray);background:#efeaf7;
}
.story-block--after .story-block__label{
  color:#fff;background:var(--brand-dark);
}
.story-block__sub{font-weight:500;letter-spacing:.04em;text-transform:none;opacity:.85;margin-left:6px}
.story-block p{font-size:16px;line-height:1.7;color:var(--ink);margin:0 0 12px;max-width:none}
.story-block p:last-child{margin-bottom:0}
.story-block p strong{color:var(--brand-dark);font-weight:600}

/* Citace pod story bloky */
.story-quote{
  margin:24px 0 0;padding:18px 22px;
  background:var(--brand-soft);border-left:4px solid var(--brand-accent);
  border-radius:0 10px 10px 0;font-style:italic;color:var(--ink);
  font-size:16px;line-height:1.6;
}
.story-quote cite{
  display:block;margin-top:8px;font-style:normal;font-weight:600;
  font-size:13px;color:var(--brand-dark);letter-spacing:.02em;
}

/* Sign-only varianta story-quote (např. Geodetická kancelář — podpis bez citátu) */
.story-quote--signonly cite{margin-top:0}

/* Logo wall — varianta s PNG obrázky klientů (loga už mají vlastní rámeček) */
.logo-wall--images{grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:820px){.logo-wall--images{grid-template-columns:repeat(2,1fr);gap:18px}}
@media(max-width:480px){.logo-wall--images{grid-template-columns:1fr}}
.logo-wall--images .logo-wall__item{
  padding:0;background:transparent;border:0;
  display:flex;align-items:center;justify-content:center;
  min-height:auto;transition:transform .25s ease;
}
.logo-wall--images .logo-wall__item img{
  width:100%;height:auto;display:block;object-fit:contain;
  transition:transform .25s ease,filter .25s ease;
}
.logo-wall--images .logo-wall__item:hover img{transform:scale(1.03)}

/* Případové studie — roztažení textu na celou šířku boxu + lepší čitelnost */
.area--story{padding:32px}
@media(max-width:720px){.area--story{padding:24px}}
.area--story p{
  font-size:16px;line-height:1.7;color:var(--ink);
  max-width:none;width:100%;margin:0 0 14px;
}
.area--story p:last-child{margin-bottom:0}
.area--story p strong{color:var(--brand-dark);font-weight:600}

/* H2 na jeden řádek (desktop) — pro nadpisy, které mají zůstat nesomené */
.h2--single{max-width:none;white-space:normal}
@media(min-width:980px){.h2--single{white-space:nowrap}}

/* Claim line (Lidé · Data · Termíny · Klid) */
.claim-line{padding:48px 0;background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.claim-line__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;text-align:center}
@media(max-width:720px){.claim-line__grid{grid-template-columns:1fr 1fr;gap:24px;text-align:left}}
.stat__n{font-family:var(--font);font-weight:700;font-size:clamp(28px,3.6vw,40px);color:var(--brand-dark);line-height:1.05}
.stat__l{margin-top:8px;font-size:14px;color:var(--claim-gray);max-width:220px;margin-left:auto;margin-right:auto;line-height:1.45}
@media(max-width:720px){.stat__l{margin-left:0}}

/* Pilíře */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:32px}
@media(max-width:820px){.pillars{grid-template-columns:1fr}}
.pillar{background:#fff;border:1px solid var(--line);border-radius:var(--radius-m);padding:32px;transition:border-color .25s ease,transform .25s ease,box-shadow .25s ease;position:relative}
.pillar:hover{border-color:var(--brand-dark);transform:translateY(-4px);box-shadow:var(--shadow-md)}
.pillar__num{font-size:13px;font-weight:700;color:var(--claim-gray);letter-spacing:.14em;text-transform:uppercase;margin-bottom:16px;display:flex;align-items:center}
.pillar h3{margin-bottom:10px;color:var(--brand-dark)}
.pillar p{color:var(--claim-gray);font-size:15px;margin:0}

/* Persona */
.persona{display:grid;grid-template-columns:.85fr 1.15fr;gap:60px;align-items:center}
@media(max-width:900px){.persona{grid-template-columns:1fr;gap:40px}}
.persona__card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-l);padding:36px;position:relative}
.persona__avatar{width:80px;height:90px;background:linear-gradient(135deg,var(--brand-dark),var(--brand-accent));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:30px;margin-bottom:22px;letter-spacing:-.02em;clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%)}
.persona__card h3{margin-bottom:4px}
.persona__role{color:var(--claim-gray);font-size:14px;margin-bottom:22px}
.persona__quote{font-size:15px;font-style:italic;color:var(--ink);border-left:3px solid var(--brand-dark);padding:6px 0 6px 16px;margin:0 0 22px}
.persona dl{margin:0;display:grid;gap:14px}
.persona dt{font-weight:600;color:var(--brand-dark);font-size:14px;margin-bottom:2px}
.persona dd{margin:0;color:var(--claim-gray);font-size:14px;line-height:1.55}

/* Funkční oblasti – table-like */
.areas{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:36px}
@media(max-width:820px){.areas{grid-template-columns:1fr}}
.area{background:#fff;border:1px solid var(--line);border-radius:var(--radius-m);padding:24px 26px;transition:border-color .2s ease}
.area:hover{border-color:var(--brand-dark)}
.area__head{display:flex;align-items:center;gap:14px;margin-bottom:10px}
.area h3{margin:0;font-size:17px;color:var(--brand-dark)}
.area p{margin:0;color:var(--claim-gray);font-size:14px;line-height:1.55}
.area ul{margin:14px 0 0;padding:0;list-style:none;display:flex;flex-wrap:wrap;gap:6px}
.area li{font-size:12px;font-weight:500;color:var(--brand-dark);background:var(--brand-soft);padding:5px 10px;border-radius:999px}

/* Proof grid (dark) */
.proof-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:40px}
@media(max-width:820px){.proof-grid{grid-template-columns:1fr}}
.proof{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-m);padding:32px;text-align:left}
.proof__big{font-weight:700;font-size:clamp(28px,3.6vw,48px);color:#fff;line-height:1.05;letter-spacing:-.02em}
.proof__lab{margin-top:14px;color:#c0b8d8;font-size:14px;line-height:1.5}
.proof__note{margin-top:24px;font-size:12px;color:#9e93bf;font-style:italic;max-width:760px;line-height:1.55}

/* Logo wall */
.logo-wall{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:36px;align-items:center}
@media(max-width:720px){.logo-wall{grid-template-columns:repeat(2,1fr);gap:18px}}
.logo-wall__item{background:#fff;border:1px solid var(--line);border-radius:var(--radius-s);padding:24px 18px;text-align:center;color:var(--claim-gray);font-weight:600;font-size:15px;letter-spacing:.02em;transition:border-color .2s}
.logo-wall__item:hover{border-color:var(--brand-dark)}

/* FAQ */
.faq{max-width:820px;margin:36px auto 0}
.faq details{background:#fff;border:1px solid var(--line);border-radius:var(--radius-s);padding:0;margin-bottom:12px;overflow:hidden;transition:border-color .2s ease}
.faq details[open]{border-color:var(--brand-dark)}
.faq summary{padding:22px 28px;font-weight:600;font-size:17px;color:var(--brand-dark);cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"";flex:0 0 14px;width:14px;height:14px;background:var(--brand-dark);clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);transition:transform .25s ease;transform:rotate(0)}
.faq details[open] summary::after{transform:rotate(180deg);background:var(--brand-accent)}
.faq .a,
.faq details > p{padding:0 28px 22px;margin:0;color:var(--claim-gray);font-size:15px;line-height:1.65}
.faq details > p + p{padding-top:0}

/* CTA strip */
.cta-strip{background:linear-gradient(135deg,var(--brand-dark),var(--brand-deep));border-radius:var(--radius-l);padding:60px;display:grid;grid-template-columns:1.4fr 1fr;align-items:center;gap:40px;color:#fff;position:relative;overflow:hidden}
.cta-strip::before{content:"";position:absolute;right:-100px;top:-100px;width:380px;height:380px;background:radial-gradient(circle,rgba(120,85,232,.35) 0%,transparent 65%);pointer-events:none}
@media(max-width:820px){.cta-strip{grid-template-columns:1fr;padding:40px 28px;text-align:center}}
.cta-strip h2{color:#fff;font-size:clamp(26px,3vw,36px);margin-bottom:12px}
.cta-strip p{color:#d8d3eb;margin:0;max-width:none}
.cta-strip .actions{display:flex;flex-wrap:wrap;gap:14px;justify-content:flex-end}
@media(max-width:820px){.cta-strip .actions{justify-content:center}}
.cta-strip .btn--primary{background:var(--brand-accent);color:#fff}
.cta-strip .btn--primary:hover{background:#fff;color:var(--brand-dark)}
.cta-strip .btn--outline{color:#fff;border-color:rgba(255,255,255,.6)}
.cta-strip .btn--outline:hover{background:#fff;color:var(--brand-dark)}

/* Breadcrumb */
.breadcrumb{font-size:13px;color:var(--claim-gray);margin-bottom:24px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.breadcrumb a{color:var(--claim-gray)}
.breadcrumb a:hover{color:var(--brand-dark)}
.breadcrumb__sep{color:var(--gray-300)}
.breadcrumb [aria-current="page"]{color:var(--brand-dark);font-weight:600}

/* Page header (inner pages) */
.page-hero{padding:80px 0 40px;background:
  radial-gradient(circle at 15% 0%, var(--brand-soft) 0%, transparent 40%),
  #fff
}
.page-hero h1{font-size:clamp(36px,4.5vw,56px);max-width:880px}
.page-hero .lead{font-size:18px;max-width:680px}

/* Pricing cards */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:36px}
@media(max-width:900px){.price-grid{grid-template-columns:1fr;max-width:480px;margin-left:auto;margin-right:auto}}
.price{background:#fff;border:1px solid var(--line);border-radius:var(--radius-m);padding:32px;display:flex;flex-direction:column;gap:18px;transition:border-color .2s,transform .2s;position:relative}
.price--recommended{border-color:var(--brand-accent)}

/* Bottom recommendation badge pro všechny tarify */
.price__rec{
  margin-top:14px;padding-top:14px;
  border-top:1px solid var(--line);
  font-size:13px;color:var(--claim-gray);text-align:center;font-weight:500;
}
.price__rec strong{color:var(--brand-dark);font-weight:700}
.price--featured .price__rec{border-top-color:rgba(58,22,133,.15)}
.price:hover{border-color:var(--brand-dark);transform:translateY(-4px)}
.price--featured{border-color:var(--brand-dark);background:var(--brand-soft);position:relative}
.price--featured::before{content:"Nejčastější volba";position:absolute;top:-12px;right:18px;background:var(--brand-dark);color:#fff;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:6px 14px;border-radius:999px;text-align:center;line-height:1.2}
.price__name{font-size:13px;font-weight:700;color:var(--claim-gray);letter-spacing:.14em;text-transform:uppercase}
.price__amount{font-size:38px;font-weight:700;color:var(--brand-dark);line-height:1}
.price__amount small{font-size:14px;font-weight:400;color:var(--claim-gray);margin-left:4px}
.price__unit{font-size:15px;font-weight:500;color:var(--claim-gray);margin-left:6px;letter-spacing:.01em}
.footnote{font-size:13px;color:var(--claim-gray);line-height:1.55;font-style:italic}
.footnote strong{font-style:normal;font-weight:600;color:var(--brand-dark)}

/* Srovnávací blok pod ceníkem (PERSONIQO vs běžná konkurence) */
.price-compare{
  margin-top:56px;background:var(--brand-soft);
  border:1px solid var(--brand-soft-2);border-radius:var(--radius-l);
  padding:40px 36px;
}
@media(max-width:720px){.price-compare{padding:28px 22px}}
.price-compare__head{text-align:center;margin-bottom:28px}
.price-compare__head h3{margin:8px 0 0;font-size:clamp(20px,2.2vw,26px);color:var(--brand-dark)}
.price-compare__head h3 strong{color:var(--brand-accent)}
.price-compare__row{
  display:grid;grid-template-columns:1fr auto 1fr;gap:24px;align-items:stretch;
}
@media(max-width:720px){.price-compare__row{grid-template-columns:1fr;gap:18px}}
.price-compare__col{
  background:#fff;border-radius:var(--radius-m);padding:28px 24px;
  border:1px solid var(--line);text-align:center;
  display:flex;flex-direction:column;gap:6px;
}
.price-compare__col--us{border-color:var(--brand-dark);box-shadow:0 6px 20px rgba(58,22,133,.08)}
.price-compare__col--them{opacity:.85}
.price-compare__big{
  font-family:var(--font);font-weight:700;
  font-size:clamp(34px,4vw,48px);line-height:1.05;color:var(--brand-dark);
}
.price-compare__col--them .price-compare__big{color:var(--claim-gray)}
.price-compare__lab{font-size:13px;color:var(--claim-gray);font-weight:500}
.price-compare__brand{
  margin-top:10px;font-size:12px;font-weight:700;letter-spacing:.16em;
  text-transform:uppercase;color:var(--brand-dark);
}
.price-compare__col--them .price-compare__brand{color:var(--claim-gray)}
.price-compare__note{
  margin:10px 0 0;font-size:13px;color:var(--claim-gray);line-height:1.5;text-align:center;
}
.price-compare__vs{
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font);font-weight:700;font-size:18px;
  color:var(--brand-accent);letter-spacing:.06em;
  padding:0 6px;
}
@media(max-width:720px){.price-compare__vs{padding:0;font-size:14px}}
.price-compare__foot{
  margin:24px 0 0;text-align:center;font-size:16px;color:var(--ink);
}
.price-compare__foot strong{color:var(--brand-dark);font-weight:700}
.price__desc{color:var(--claim-gray);font-size:14px;margin:0}
.price__list{margin:0;padding:0;list-style:none;display:grid;gap:10px}
.price__list li{display:flex;gap:10px;font-size:14px;color:var(--ink);line-height:1.5}
.price__list li::before{content:"";flex:0 0 12px;width:12px;height:13px;margin-top:5px;background:var(--brand-dark);clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%)}

/* Forms */
.form{display:grid;gap:18px;max-width:540px}
.form__row{display:grid;gap:6px}
.form__row label{font-size:14px;font-weight:600;color:var(--brand-dark)}
.form__row input,.form__row textarea,.form__row select{font-family:var(--font);font-size:15px;padding:12px 14px;border:1.5px solid var(--line);border-radius:8px;background:#fff;color:var(--ink);transition:border-color .15s}
.form__row input:focus,.form__row textarea:focus,.form__row select:focus{outline:none;border-color:var(--brand-dark)}
.form__row textarea{min-height:120px;resize:vertical;font-family:inherit}
.form__hint{font-size:12px;color:var(--claim-gray)}
.form__check{display:flex;gap:10px;font-size:14px;color:var(--claim-gray);line-height:1.5}
.form__check input{flex:0 0 auto;width:18px;height:18px;margin-top:2px;accent-color:var(--brand-dark)}

/* Logo wall */
.logo-wall{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:36px;align-items:center}
@media(max-width:720px){.logo-wall{grid-template-columns:repeat(2,1fr);gap:18px}}
.logo-wall__item{background:#fff;border:1px solid var(--line);border-radius:var(--radius-s);padding:24px 18px;text-align:center;color:var(--claim-gray);font-weight:600;font-size:15px;letter-spacing:.02em;transition:all .25s ease}
.logo-wall__item:hover{transform:translateY(-3px);border-color:var(--brand-accent);box-shadow:var(--shadow-sm)}

/* Footer */
.foot{padding:56px 0 32px;background:#fff;border-top:1px solid var(--line);color:var(--claim-gray);font-size:14px}
.foot__top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;margin-bottom:36px;align-items:start}
@media(max-width:820px){.foot__top{grid-template-columns:1fr 1fr;gap:32px}}
@media(max-width:520px){.foot__top{grid-template-columns:1fr}}
.foot__brand img{height:100px;width:auto;margin:0 0 14px;max-width:100%;display:block}
@media(max-width:520px){.foot__brand img{height:70px}}
/* P v PERSONIQO ve wordmarku začíná v SVG na x≈6 (z viewBoxu 273.6).
   Při výšce 100 px to vychází na ~10 px od levého okraje obrázku. */
.foot__brand p{font-size:14px;color:var(--claim-gray);max-width:300px;margin:0;padding-left:10px;line-height:1.6}
@media(max-width:520px){.foot__brand p{padding-left:7px}}
.foot__brand p a{color:var(--brand-dark)}
.foot__brand p a:hover{color:var(--brand-accent)}
.foot__col h4{color:var(--brand-dark);font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;margin-bottom:14px}
.foot__col ul{margin:0;padding:0;list-style:none;display:grid;gap:8px}
.foot__col a{color:var(--claim-gray)}
.foot__col a:hover{color:var(--brand-accent)}
.foot__bot{padding-top:28px;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;gap:18px;justify-content:space-between;align-items:center;color:var(--claim-gray);font-size:13px}
.foot__bot .mwl{display:inline-flex;align-items:center;gap:12px}
.foot__bot .mwl a{display:inline-block;line-height:0}
.foot__bot .mwl img{height:20px;width:auto;opacity:.9;transition:opacity .2s}
.foot__bot .mwl a:hover img{opacity:1}

/* Sticky bottom CTA on mobile */
.sticky-cta{display:none;position:fixed;bottom:0;left:0;right:0;z-index:90;background:#fff;border-top:1px solid var(--line);padding:12px 16px;justify-content:center;box-shadow:0 -8px 24px rgba(31,10,74,.08)}
.sticky-cta .btn{width:100%;max-width:360px;justify-content:center}
@media(max-width:720px){.sticky-cta{display:flex}body{padding-bottom:80px}}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.001ms !important;
    scroll-behavior:auto !important;
  }
  html{scroll-behavior:auto}
  .btn:hover,.pillar:hover,.price:hover,.area:hover{transform:none}
}

/* Utility classes */
.u-mt-l{margin-top:24px}
.u-mt-xl{margin-top:36px}
.u-max-680{max-width:680px}
.u-max-780{max-width:780px}
.u-center{text-align:center}
.u-mx-auto{margin-left:auto;margin-right:auto}
.u-grid-1col{grid-template-columns:1fr !important}
.u-full{max-width:100% !important;width:100%}
.lead.u-full{max-width:100% !important}
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:start}
.contact-grid .areas{margin-top:32px;grid-template-columns:1fr}
@media(max-width:900px){.contact-grid{grid-template-columns:1fr;gap:40px}}

/* === HRAVĚJŠÍ / MODERNĚJŠÍ POLISH === */
@keyframes hex-float {
  0%,100% { transform: translateY(0) }
  50%     { transform: translateY(-8px) }
}
.hex-art__main,.hexik-stage{animation:hex-float 6s ease-in-out infinite}
.hexik-stage{transform-origin:center}

@keyframes bubble-pop {
  0% { transform:rotate(2deg) scale(.92); opacity:0 }
  60%{ transform:rotate(2deg) scale(1.04); opacity:1 }
  100%{ transform:rotate(2deg) scale(1) }
}
.speech-bubble{animation:bubble-pop .9s ease-out .35s both}

.cta-strip::after{
  content:"";position:absolute;left:-30%;top:-50%;width:60%;height:200%;
  background:linear-gradient(60deg,transparent 40%,rgba(255,255,255,.06) 50%,transparent 60%);
  animation:sweep 8s ease-in-out infinite;pointer-events:none
}
@keyframes sweep {
  0%,100% { transform: translateX(-30%) rotate(0deg); opacity:.6 }
  50%     { transform: translateX(160%) rotate(2deg); opacity:1 }
}

.pillar{overflow:hidden}
.pillar::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--brand-accent),var(--brand-dark),var(--brand-accent));
  background-size:200% 100%;opacity:0;transition:opacity .25s ease;animation:gradient-flow 4s linear infinite;
}
.pillar:hover::before{opacity:1}
@keyframes gradient-flow {
  0%   { background-position: 0% 50% }
  100% { background-position: 200% 50% }
}

.area{position:relative;overflow:hidden}
.area::after{
  content:"";position:absolute;right:-40px;top:-40px;width:140px;height:160px;
  background:radial-gradient(circle, rgba(120,85,232,.12) 0%, transparent 65%);
  opacity:0;transition:opacity .3s ease;pointer-events:none
}
.area:hover{transform:translateY(-3px);box-shadow:var(--shadow-sm)}
.area:hover::after{opacity:1}

.area:hover .hex-tile{transform:rotate(-6deg) scale(1.08);transition:transform .35s cubic-bezier(.34,1.56,.64,1)}
.hex-tile{transition:transform .25s ease}

.tag-soft{transition:all .2s ease}
.tag-soft:hover{background:var(--brand-dark);color:#fff;transform:translateY(-2px)}

.faq details[open]{box-shadow:0 6px 20px rgba(58,22,133,.08)}
.faq summary{transition:padding-left .2s ease;position:relative}
.faq details[open] summary{padding-left:36px}
.faq details[open] summary::before{
  content:"";position:absolute;left:14px;top:50%;width:6px;height:24px;
  border-radius:3px;background:linear-gradient(180deg,var(--brand-accent),var(--brand-dark));
  transform:translateY(-50%)
}

@keyframes grid-drift {
  0%,100% { transform: translate(0,0) }
  50%     { transform: translate(-12px,-8px) }
}
.hex-art__bg{animation:grid-drift 12s ease-in-out infinite}

.trust-bar{position:relative;overflow:hidden}
.trust-bar::before{
  content:"";position:absolute;left:-20px;top:-20px;width:100px;height:100px;
  background:radial-gradient(circle, rgba(120,85,232,.15) 0%, transparent 65%);pointer-events:none
}

@keyframes fade-up {
  from { opacity:0; transform:translateY(12px) }
  to   { opacity:1; transform:translateY(0) }
}
.hero__wordmark,.hero h1,.hero .lead,.hero__cta,.hero__reassure,.trust-bar{animation:fade-up .55s ease-out both}
.hero h1{animation-delay:.05s}
.hero .lead{animation-delay:.1s}
.hero__cta{animation-delay:.15s}
.hero__reassure{animation-delay:.2s}
.trust-bar{animation-delay:.25s}

.mockup{transition:all .25s ease}
.mockup:hover{transform:translateY(-4px);box-shadow:0 36px 80px rgba(58,22,133,.18)}
.mockup__placeholder{transition:transform .25s ease}
.mockup:hover .mockup__placeholder{transform:scale(1.04)}

@keyframes avatar-glow {
  0%,100% { box-shadow: 0 0 0 0 rgba(120,85,232,.4) }
  50%     { box-shadow: 0 0 0 14px rgba(120,85,232,0) }
}
.persona__avatar{animation:avatar-glow 2.6s ease-in-out infinite}

.price--featured{transform:scale(1.02)}
.price--featured:hover{transform:scale(1.02) translateY(-4px)}

.section--soft{position:relative;overflow:hidden}
.section--soft::before{
  content:"";position:absolute;right:-100px;bottom:-100px;width:340px;height:380px;
  clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);
  background:linear-gradient(135deg, rgba(120,85,232,.05), transparent);
  pointer-events:none;z-index:0
}
.section--soft > .wrap{position:relative;z-index:1}

@media (prefers-reduced-motion: reduce){
  .hex-art__main,.hexik-stage,.speech-bubble,.cta-strip::after,.pillar::before,
  .persona__avatar,.hex-art__bg,.hero__wordmark,.hero h1,.hero .lead,
  .hero__cta,.hero__reassure,.trust-bar{animation:none !important}
}

/* Print */
@media print{
  .nav,.sticky-cta,.cta-strip,.foot__bot{display:none}
  body{color:#000;background:#fff}
  a{color:#000;text-decoration:underline}
}
