/*
Theme Name: HlídejVodu.cz
Theme URI: https://www.hlidejvodu.cz
Author: HlídejVodu.cz
Author URI: https://www.hlidejvodu.cz
Description: Firemní motiv pro HlídejVodu.cz — chytrý monitoring a úspory vody. Klasický PHP motiv s vlastním typem obsahu „Reference", blogem a kompletními šablonami stránek. Navržen podle referenčního designu z Claude Design.
Version: 1.6.9
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: hlidejvodu
Tags: business, services, custom-colors, custom-menu, featured-images, translation-ready
*/

/* ===== HlídejVodu.cz — shared site styles ===== */
:root{
  --ink:#0F1230; --ink-2:#2E2C5E; --ink-3:#5B5E85;
  --brand-deep:#2A2566; --brand-mid:#3F4FA0; --brand:#4A77C7;
  --brand-aqua:#5BC2D9; --brand-aqua-2:#8FDDEC;
  --paper:#F4F7FB; --paper-2:#E7EEF7; --white:#fff;
  --line:rgba(15,18,48,0.10); --line-strong:rgba(15,18,48,0.20);
  --good:#19B68A; --warn:#E5484D; --gold:#F4B73A;
  --grad-brand:linear-gradient(135deg,#2A2566 0%,#3F4FA0 50%,#5BC2D9 100%);
  --grad-brand-vert:linear-gradient(165deg,#241F5C 0%,#33408C 55%,#4A77C7 100%);
  --grad-paper:linear-gradient(180deg,#F4F7FB 0%,#E7EEF7 100%);
  --shadow:0 24px 60px -30px rgba(15,18,48,0.20);
  --shadow-lg:0 40px 90px -40px rgba(15,18,48,0.35);
  --r:20px; --maxw:1240px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Rubik',system-ui,sans-serif;color:var(--ink);background:var(--white);-webkit-font-smoothing:antialiased;line-height:1.5}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.sr{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}

/* type */
h1,h2,h3{letter-spacing:-0.02em;line-height:1.05;margin:0}
.eyebrow{display:inline-flex;align-items:center;gap:12px;font-weight:600;font-size:14px;letter-spacing:0.2em;text-transform:uppercase;color:var(--brand)}
.eyebrow .ln{width:36px;height:2px;background:currentColor;opacity:.6}
.grad-text{background:var(--grad-brand);-webkit-background-clip:text;background-clip:text;color:transparent}
.lead{font-size:clamp(18px,2.2vw,22px);color:var(--ink-2);line-height:1.6}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:10px;font-weight:600;font-size:17px;padding:15px 26px;border-radius:20px;border:1px solid transparent;cursor:pointer;transition:transform .2s,box-shadow .2s,background .2s}
.btn svg{width:18px;height:18px}
.btn-primary{background:linear-gradient(135deg,#2A2566 0%,#3F4FA0 100%);color:#fff;box-shadow:0 14px 30px -12px rgba(42,37,102,.55)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 20px 40px -14px rgba(74,119,199,.7)}
.btn-ghost{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.25)}
.btn-ghost:hover{background:rgba(255,255,255,.16)}
.btn-light{background:#fff;color:var(--brand-deep);border-color:var(--line)}
.btn-light:hover{transform:translateY(-2px);box-shadow:var(--shadow)}

/* header */
.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.82);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);transition:box-shadow .3s}
.nav.scrolled{box-shadow:0 10px 30px -20px rgba(15,18,48,.4)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:76px}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:21px;color:var(--brand-deep);letter-spacing:-0.01em}
.brand-logo{height:48px;width:auto;display:block}
.foot .brand-logo{height:43px}
@media (max-width:560px){.brand-logo{height:41px}}
.brand .chip{width:42px;height:42px;border-radius:11px;background:var(--grad-brand);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.brand .chip img{width:30px;height:auto}
.nav-links{display:flex;align-items:center;gap:6px}
.nav-links a{font-size:16px;font-weight:500;color:var(--ink-2);padding:10px 14px;border-radius:10px;transition:background .2s,color .2s}
.nav-links a:hover{background:var(--paper);color:var(--brand-deep)}
.nav-links a.active{color:var(--brand);font-weight:600}
.nav-links a.nav-cta{margin-left:8px;color:#fff;border-radius:20px;padding-left:32px;padding-right:32px}
.nav-links a.nav-cta:hover{color:#fff;background:transparent}
.burger{display:none;width:46px;height:46px;border:1px solid var(--line);border-radius:12px;background:#fff;cursor:pointer;align-items:center;justify-content:center;flex-direction:column;gap:5px}
.burger span{width:20px;height:2px;background:var(--ink);border-radius:2px;transition:.25s}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* sections */
.section{padding:clamp(64px,9vw,120px) 0}
.section.tight{padding:clamp(48px,6vw,80px) 0}
.bg-paper{background:var(--grad-paper)}
.bg-dark{background:var(--grad-brand-vert);color:#fff}
.bg-dark .lead{color:rgba(255,255,255,.84)}
.bg-dark .eyebrow{color:var(--brand-aqua)}
.center{text-align:center}
.head-block{max-width:760px}
.center .head-block{margin:0 auto}
.section h2{font-size:clamp(32px,4.6vw,58px);font-weight:800;margin:18px 0 18px}

/* cards / grids */
.grid{display:grid;gap:24px}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:32px;box-shadow:var(--shadow);transition:transform .3s,box-shadow .3s}
.card.hover:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.card .ic{width:58px;height:58px;border-radius:15px;background:var(--paper-2);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.card .ic svg{width:28px;height:28px;stroke:var(--brand-mid)}
.card h3{font-size:23px;font-weight:700;margin-bottom:8px}
.card p{margin:0;color:var(--ink-3);font-size:17px}
.bg-dark .card{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.14);color:#fff}
.bg-dark .card p{color:rgba(255,255,255,.72)}

/* pills + chips */
.pill{display:inline-flex;align-items:center;gap:9px;padding:9px 16px;border-radius:999px;background:rgba(74,119,199,.1);color:var(--brand);font-weight:600;font-size:14px;border:1px solid rgba(74,119,199,.22)}
.pill.dark{background:rgba(255,255,255,.1);color:var(--brand-aqua-2);border-color:rgba(255,255,255,.2)}
.dot{width:9px;height:9px;border-radius:50%;background:var(--good);position:relative}
.dot::after{content:"";position:absolute;inset:-3px;border-radius:50%;background:currentColor;color:var(--good);opacity:.5;animation:pulse 1.8s ease-out infinite}
@keyframes pulse{0%{transform:scale(.6);opacity:.5}80%{transform:scale(2.4);opacity:0}100%{opacity:0}}

/* stats */
.stat .n{font-size:clamp(40px,5vw,64px);font-weight:800;letter-spacing:-0.03em;color:var(--brand-deep);line-height:1}
.bg-dark .stat .n{color:#fff}
.stat .l{font-size:15px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3);margin-top:8px}
.bg-dark .stat .l{color:rgba(255,255,255,.66)}

/* hero */
.hero{position:relative;overflow:hidden;background:var(--grad-brand-vert);color:#fff}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;padding:clamp(56px,8vw,104px) 0}
.hero h1{font-size:clamp(40px,6vw,80px);font-weight:800}
.hero .lead{color:rgba(255,255,255,.86);max-width:560px;margin-top:22px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px}
.hero-photo{border-radius:24px;overflow:hidden;border:1px solid rgba(255,255,255,.16);box-shadow:var(--shadow-lg);aspect-ratio:4/3}
.hero-photo img{width:100%;height:100%;object-fit:cover}
.hero .drops{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.hero .drops i{position:absolute;top:-16px;width:6px;height:6px;border-radius:50% 50% 50% 0;background:rgba(143,221,236,.5);transform:rotate(45deg);animation:fall linear infinite}
@keyframes fall{0%{transform:translateY(-20px) rotate(45deg);opacity:0}10%{opacity:1}90%{opacity:.8}100%{transform:translateY(120vh) rotate(45deg);opacity:0}}

/* footer */
.foot{background:#0E1130;color:rgba(255,255,255,.7);padding:64px 0 32px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px;margin-bottom:44px}
.foot .brand{color:#fff}
.foot .brand .chip{background:var(--grad-brand)}
.foot h4{color:#fff;font-size:15px;letter-spacing:.06em;text-transform:uppercase;margin:0 0 16px}
.foot ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.foot a:hover{color:var(--brand-aqua-2)}
.foot .muted{font-size:15px;line-height:1.7;color:rgba(255,255,255,.55)}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:14px;color:rgba(255,255,255,.45)}
.foot-social{display:flex;gap:12px;margin-top:20px}
.foot-contact li a{color:#fff;font-weight:600}
.foot-contact li a:hover{color:var(--brand-aqua-2)}
.foot-social.in-contact{margin-top:18px}
.foot-social a{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:11px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);transition:background .2s,border-color .2s,transform .2s}
.foot-social a:hover{background:rgba(91,194,217,.18);border-color:rgba(91,194,217,.4);transform:translateY(-2px)}
.foot-social a svg{width:21px;height:21px;fill:#fff}

/* reveal on scroll — hidden ONLY while .anim is set and .in is absent, so content is bulletproof */
.reveal{transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
html.anim .reveal:not(.in){opacity:0;transform:translateY(28px)}
.reveal[data-d="1"]{transition-delay:.1s}.reveal[data-d="2"]{transition-delay:.2s}.reveal[data-d="3"]{transition-delay:.3s}.reveal[data-d="4"]{transition-delay:.4s}.reveal[data-d="5"]{transition-delay:.5s}
@media (prefers-reduced-motion:reduce){.reveal{transition:none}html.anim .reveal:not(.in){opacity:1;transform:none}.hero .drops{display:none}.dot::after{animation:none}}

/* media image card */
.media{border-radius:var(--r);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);position:relative;background:var(--paper-2)}
.media img{width:100%;height:100%;object-fit:cover;aspect-ratio:16/10}
.media .cap{position:absolute;left:16px;bottom:16px;padding:8px 15px;border-radius:999px;background:rgba(15,18,48,.62);color:#fff;font-size:14px;font-weight:600;backdrop-filter:blur(6px);display:flex;align-items:center;gap:8px}
.media .cap .pin{width:8px;height:8px;border-radius:50%;background:var(--brand-aqua)}

.media-ph{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;aspect-ratio:16/10;width:100%;background:linear-gradient(135deg,#EAF1FA 0%,#D7E7F2 100%);color:var(--brand-deep)}
.media-ph svg{width:64px;height:64px}
.media-ph span{font-weight:700;font-size:19px;letter-spacing:-.01em}
.hero-photo .media-ph{border-radius:var(--r);border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.06);color:#fff}
.hero-photo .media-ph svg{stroke:var(--brand-aqua-2)}

/* cta band */
.logo-wall .logo-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);min-height:160px;display:flex;align-items:center;justify-content:center;padding:30px 36px;box-shadow:var(--shadow)}
.logo-wall .logo-card img{max-width:100%;max-height:92px;width:auto;height:auto;object-fit:contain}
.logo-wall .logo-card .ph{display:none;font-weight:800;font-size:20px;color:var(--brand-deep);text-align:center;letter-spacing:-.01em}
.logo-wall .logo-card .ph.show{display:block}
.logo-wall-3{grid-template-columns:repeat(3,1fr);gap:20px}
@media (max-width:760px){.logo-wall-3{grid-template-columns:repeat(2,1fr)}}
.cta-band{background:var(--grad-brand);color:#fff;border-radius:28px;padding:clamp(40px,6vw,72px);text-align:center;box-shadow:var(--shadow-lg)}
.cta-band h2{font-size:clamp(30px,4.4vw,52px);font-weight:800;margin-bottom:14px}
.cta-band .lead{color:rgba(255,255,255,.86);max-width:620px;margin:0 auto 28px}

/* service detail */
.crumb{display:inline-flex;align-items:center;gap:9px;font-size:14px;font-weight:600;color:rgba(255,255,255,.62);margin-bottom:22px;flex-wrap:wrap}
.crumb a:hover{color:#fff}
.crumb svg{width:14px;height:14px;opacity:.6}
.crumb .here{color:var(--brand-aqua-2)}
.detail{display:grid;grid-template-columns:1.12fr .88fr;gap:52px;align-items:start}
.detail h2{font-size:clamp(28px,3.4vw,40px);font-weight:800;margin:0 0 18px}
.detail p{color:var(--ink-2);font-size:18px;line-height:1.65}
.ulcheck{list-style:none;margin:24px 0 0;padding:0;display:flex;flex-direction:column;gap:16px}
.ulcheck li{display:flex;gap:14px;align-items:flex-start;font-size:18px;color:var(--ink-2);line-height:1.5}
.ulcheck li b{color:var(--ink);font-weight:600}
.ulcheck li svg{width:28px;height:28px;flex:0 0 28px;margin-top:1px;padding:6px;border-radius:9px;background:rgba(25,182,138,.12);stroke:var(--good)}
.aside{position:sticky;top:96px;background:var(--grad-brand);color:#fff;border-radius:24px;padding:36px;box-shadow:var(--shadow-lg)}
.aside h3{color:#fff;font-size:22px;margin-bottom:10px}
.aside p{color:rgba(255,255,255,.82);font-size:16px;line-height:1.6;margin:0 0 18px}
.aside .big{font-size:clamp(44px,5vw,58px);font-weight:800;letter-spacing:-.03em;line-height:1;margin:4px 0 2px}
.aside .lbl{font-size:14px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:rgba(255,255,255,.7)}
.aside .hr{height:1px;background:rgba(255,255,255,.16);margin:22px 0}
.aside .row{display:flex;align-items:center;gap:12px;font-size:16px;margin-top:12px}
.aside .row svg{width:20px;height:20px;flex:0 0 20px;stroke:var(--brand-aqua-2)}
.aside .btn{margin-top:24px;width:100%;justify-content:center}

/* service hub cards as links + wide feature card */
a.card{color:inherit;display:block}
a.card .more{display:inline-flex;align-items:center;gap:7px;margin-top:16px;font-weight:600;font-size:15px;color:var(--brand)}
a.card .more svg{width:16px;height:16px;stroke:var(--brand);transition:transform .25s}
a.card:hover .more svg{transform:translateX(4px)}
.svc-wide{grid-column:1/-1;background:var(--grad-brand-vert);color:#fff;border:0;display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center}
.svc-wide h3{font-size:clamp(24px,3vw,34px);color:#fff;margin-bottom:10px}
.svc-wide p{color:rgba(255,255,255,.8);font-size:18px}
.svc-wide .ic{background:rgba(255,255,255,.12);margin-bottom:16px}
.svc-wide .ic svg{stroke:var(--brand-aqua-2)}
.svc-wide .more{color:var(--brand-aqua-2)}.svc-wide .more svg{stroke:var(--brand-aqua-2)}
.svc-wide .svc-wide-more{grid-column:1/-1;margin-top:8px;font-weight:600;font-size:16px;color:#fff}
.svc-wide .svc-wide-more svg{stroke:#fff}
.svc-tags{list-style:none;margin:0;padding:26px 28px;display:grid;grid-template-columns:1fr 1fr;gap:14px 24px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);border-radius:18px}
.svc-tags li{display:flex;align-items:center;gap:11px;font-size:15px;font-weight:500;color:rgba(255,255,255,.82);line-height:1.3}
.svc-tags li::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--brand-aqua);flex:0 0 7px}

/* FAQ accordion */
.faq{max-width:880px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.faq details{background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;transition:border-color .2s,box-shadow .2s}
.faq details[open]{border-color:rgba(74,119,199,.4);box-shadow:var(--shadow-lg)}
.faq summary{list-style:none;cursor:pointer;padding:26px 30px;display:flex;align-items:center;justify-content:space-between;gap:20px;font-weight:600;font-size:19px;color:var(--ink)}
.faq summary::-webkit-details-marker{display:none}
.faq summary .q-ic{flex:0 0 30px;width:30px;height:30px;border-radius:9px;background:var(--paper);display:flex;align-items:center;justify-content:center;transition:transform .25s,background .2s}
.faq details[open] summary .q-ic{transform:rotate(45deg);background:var(--brand-aqua)}
.faq summary .q-ic svg{width:16px;height:16px;stroke:var(--brand-deep);stroke-width:2.4}
.faq details[open] summary .q-ic svg{stroke:#fff}
.faq .a{padding:0 30px 28px;color:var(--ink-2);font-size:17px;line-height:1.65}
.faq .a a{color:var(--brand);font-weight:600}
@media (max-width:960px){
  .detail{grid-template-columns:1fr;gap:32px}
  .aside{position:static}
  .svc-wide{grid-template-columns:1fr;gap:20px}
}

/* ===== case study ===== */
.case-hero{display:grid;grid-template-columns:1.04fr .96fr;gap:52px;align-items:center}
.case-hero .hero-photo{aspect-ratio:4/3}
.kpi-band{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.kpi{background:#fff;border:1px solid var(--line);border-radius:20px;padding:32px;box-shadow:var(--shadow)}
.kpi .n{font-size:clamp(40px,5vw,58px);font-weight:800;letter-spacing:-.03em;line-height:1;color:var(--brand-deep)}
.kpi .n.good{color:var(--good)}
.kpi .l{font-size:16px;color:var(--ink-3);margin-top:10px;line-height:1.4;font-weight:500}
.phase{display:grid;grid-template-columns:auto 1fr;gap:28px;align-items:start;padding:0 0 8px}
.phase+.phase{margin-top:14px}
.phase .tag{display:inline-flex;align-items:center;justify-content:center;min-width:120px;padding:9px 0;border-radius:999px;font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.phase.bad .tag{background:rgba(229,72,77,.1);color:var(--warn)}
.phase.act .tag{background:rgba(74,119,199,.12);color:var(--brand)}
.phase.win .tag{background:rgba(25,182,138,.12);color:var(--good)}
.phase h3{font-size:clamp(22px,2.6vw,30px);font-weight:700;margin:0 0 10px;color:var(--ink)}
.phase p{color:var(--ink-2);font-size:17px;line-height:1.62;margin:0}
.phase ul{list-style:none;margin:14px 0 0;padding:0;display:flex;flex-direction:column;gap:11px}
.phase ul li{display:flex;gap:12px;align-items:flex-start;font-size:16px;color:var(--ink-2);line-height:1.5}
.phase ul li svg{width:24px;height:24px;flex:0 0 24px;margin-top:1px;padding:5px;border-radius:8px;background:rgba(25,182,138,.12);stroke:var(--good)}
.case-quote{background:var(--grad-brand-vert);color:#fff;border-radius:28px;padding:clamp(40px,6vw,64px);box-shadow:var(--shadow-lg);position:relative;overflow:hidden}
.case-quote .mark{font-size:120px;line-height:.7;font-weight:800;color:rgba(143,221,236,.32);font-family:Georgia,serif}
.case-quote p{font-size:clamp(22px,3vw,32px);font-weight:600;line-height:1.4;max-width:900px;margin:6px 0 22px}
.case-quote .by{color:var(--brand-aqua-2);font-weight:600;font-size:16px}
.case-nav{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}
.case-nav a{display:inline-flex;align-items:center;gap:10px;font-weight:600;color:var(--brand);font-size:16px}
.case-nav a svg{width:18px;height:18px;stroke:var(--brand)}
.case-meta{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}
.case-meta .pill{background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.2)}
@media (max-width:960px){
  .case-hero{grid-template-columns:1fr;gap:32px}
  .kpi-band{grid-template-columns:1fr}
  .phase{grid-template-columns:1fr;gap:12px}
  .phase .tag{min-width:0;width:max-content;padding:8px 16px}
}

/* responsive */
@media (max-width:960px){
  .nav-links{position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;align-items:stretch;gap:0;padding:12px 18px 24px;border-bottom:1px solid var(--line);transform:translateY(-130%);transition:transform .3s;box-shadow:var(--shadow)}
  .nav-links.open{transform:none}
  .nav-links a{padding:14px 12px;font-size:18px}
  .nav-cta{margin:10px 0 0}
  .burger{display:flex}
  .hero-grid{grid-template-columns:1fr;gap:32px}
  .hero-photo{aspect-ratio:16/10}
  .g4{grid-template-columns:repeat(2,1fr)}
  .g3{grid-template-columns:1fr}
  .g2{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:560px){
  .g4{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .nav-in{height:68px}
}

/* ===== O nás — values, team, stats ===== */
.value{display:flex;flex-direction:column;gap:14px}
.value .ic{width:60px;height:60px;border-radius:16px;background:var(--paper-2);display:flex;align-items:center;justify-content:center}
.value .ic svg{width:28px;height:28px;stroke:var(--brand);fill:none;stroke-width:1.7}
.value h3{font-size:22px;font-weight:700;color:var(--ink)}
.value p{color:var(--ink-2);font-size:17px;line-height:1.6}
.stat-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.stat-strip .s{text-align:center;padding:20px}
.stat-strip .s .n{font-size:clamp(38px,5vw,56px);font-weight:800;letter-spacing:-.03em;line-height:1;color:#fff}
.stat-strip .s .l{font-size:15px;color:rgba(255,255,255,.7);margin-top:10px;font-weight:500;letter-spacing:.02em}
.team{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.member{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);transition:transform .25s,box-shadow .25s}
.member:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.member .ph{aspect-ratio:1/1;background:linear-gradient(150deg,#33408C,#5BC2D9);display:flex;align-items:center;justify-content:center;color:#fff;font-size:46px;font-weight:800;letter-spacing:-.02em}
.member .ph img{width:100%;height:100%;object-fit:cover}
.member .b{padding:24px 26px}
.aside-photo{position:sticky;top:96px;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:4/5}
.aside-photo img{width:100%;height:100%;object-fit:cover;display:block}
@media (max-width:960px){.aside-photo{position:static;aspect-ratio:16/10}}
.member .b h3{font-size:21px;font-weight:700;color:var(--ink)}
.member .b .role{color:var(--brand);font-weight:600;font-size:15px;margin-top:4px}
.member .b p{color:var(--ink-3);font-size:15px;line-height:1.55;margin-top:12px}
@media (max-width:960px){.stat-strip{grid-template-columns:repeat(2,1fr)}.team{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.team{grid-template-columns:1fr}}

/* ===== Kariéra — jobs ===== */
.perks{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.perk{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:28px 26px;box-shadow:var(--shadow)}
.perk .ic{width:50px;height:50px;border-radius:13px;background:var(--paper-2);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.perk .ic svg{width:25px;height:25px;stroke:var(--brand);fill:none;stroke-width:1.7}
.perk h3{font-size:18px;font-weight:700;color:var(--ink);margin-bottom:6px}
.perk p{color:var(--ink-3);font-size:15px;line-height:1.5}
.jobs{display:flex;flex-direction:column;gap:16px}
.job{display:flex;align-items:center;gap:24px;background:#fff;border:1px solid var(--line);border-radius:18px;padding:26px 30px;box-shadow:var(--shadow);transition:border-color .2s,transform .2s,box-shadow .2s}
.job:hover{border-color:rgba(74,119,199,.4);transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.job .jm{flex:1;min-width:0}
.job h3{font-size:21px;font-weight:700;color:var(--ink)}
.job .meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.job .chip{font-size:13px;font-weight:600;color:var(--ink-3);background:var(--paper);border:1px solid var(--line);padding:6px 13px;border-radius:999px}
.job .go{flex:0 0 auto;width:48px;height:48px;border-radius:13px;background:var(--paper);display:flex;align-items:center;justify-content:center;transition:background .2s}
.job:hover .go{background:var(--brand-aqua)}
.job .go svg{width:20px;height:20px;stroke:var(--brand-deep);stroke-width:2.2}
.job:hover .go svg{stroke:#fff}
@media (max-width:960px){.perks{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.perks{grid-template-columns:1fr}.job{flex-wrap:wrap}}

/* ===== Blog ===== */
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.post{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);transition:transform .25s,box-shadow .25s;height:100%}
.post:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.post .img{aspect-ratio:16/10;overflow:hidden;background:var(--paper-2)}
.post .img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.post:hover .img img{transform:scale(1.05)}
.post .b{padding:26px 28px;display:flex;flex-direction:column;flex:1}
.post .tagline{display:flex;align-items:center;gap:10px;font-size:13px;font-weight:600;color:var(--brand);text-transform:uppercase;letter-spacing:.06em;margin-bottom:14px}
.post .tagline .dot{width:5px;height:5px;border-radius:50%;background:var(--ink-3);opacity:.5}
.post .tagline .date{color:var(--ink-3);text-transform:none;letter-spacing:0;font-weight:500}
.post h3{font-size:22px;font-weight:700;color:var(--ink);line-height:1.25}
.post p{color:var(--ink-2);font-size:16px;line-height:1.6;margin-top:12px;flex:1}
.post .more{display:inline-flex;align-items:center;gap:7px;margin-top:18px;font-weight:600;font-size:15px;color:var(--brand)}
.post .more svg{width:16px;height:16px;stroke:var(--brand);transition:transform .25s}
.post:hover .more svg{transform:translateX(4px)}
.post.feat{grid-column:1/-1;flex-direction:row}
.post.feat .img{flex:0 0 50%;aspect-ratio:auto}
.post.feat .b{padding:clamp(28px,4vw,52px);justify-content:center}
.post.feat h3{font-size:clamp(26px,3.4vw,38px)}
.post.feat p{font-size:18px}
@media (max-width:960px){.posts{grid-template-columns:1fr 1fr}.post.feat{flex-direction:column}.post.feat .img{flex:auto;aspect-ratio:16/9}}
@media (max-width:560px){.posts{grid-template-columns:1fr}}

/* ===== Article ===== */
.article{max-width:780px;margin:0 auto}
.article .lead{font-size:clamp(20px,2.4vw,24px);color:var(--ink-2);line-height:1.55;font-weight:400;margin:0 0 8px}
.article-body{font-size:18px;line-height:1.75;color:var(--ink-2)}
.article-body>p{margin:0 0 22px}
.article-body h2{font-size:clamp(26px,3vw,32px);font-weight:800;color:var(--ink);margin:44px 0 16px}
.article-body h3{font-size:22px;font-weight:700;color:var(--ink);margin:32px 0 12px}
.article-body figure{margin:36px 0}
.article-body figure img{width:100%;border-radius:var(--r);box-shadow:var(--shadow);border:1px solid var(--line)}
.article-body figcaption{text-align:center;font-size:14px;color:var(--ink-3);margin-top:12px}
.article-body ul{margin:0 0 22px;padding-left:0;list-style:none;display:flex;flex-direction:column;gap:12px}
.article-body ul li{display:flex;gap:13px;align-items:flex-start}
.article-body ul li::before{content:"";flex:0 0 22px;width:22px;height:22px;margin-top:2px;border-radius:7px;background:rgba(25,182,138,.12) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2319B68A' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><path d='M5 12l4 4 10-10'/></svg>") center/13px no-repeat}
.article-body blockquote{margin:36px 0;padding:28px 32px;background:var(--paper);border-left:4px solid var(--brand-aqua);border-radius:0 16px 16px 0;font-size:20px;font-weight:600;color:var(--ink);line-height:1.5}
.article-meta{display:flex;align-items:center;gap:14px;flex-wrap:wrap;color:rgba(255,255,255,.7);font-size:15px;font-weight:500;margin-top:22px}
.article-meta .pill{background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.2)}
.article-share{display:flex;align-items:center;gap:14px;margin-top:48px;padding-top:32px;border-top:1px solid var(--line)}
.article-share span{font-weight:600;color:var(--ink-3);font-size:15px}

/* ===== Contact ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:52px;align-items:start}
.contact-info{display:flex;flex-direction:column;gap:18px}
.ci-card{display:flex;gap:18px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:18px;padding:24px 26px;box-shadow:var(--shadow)}
.ci-card .ic{flex:0 0 50px;width:50px;height:50px;border-radius:13px;background:var(--paper-2);display:flex;align-items:center;justify-content:center}
.ci-card .ic svg{width:24px;height:24px;stroke:var(--brand);fill:none;stroke-width:1.8}
.ci-card .l{font-size:13px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3)}
.ci-card .v{font-size:20px;font-weight:700;color:var(--ink);margin-top:3px}
.ci-card .v a:hover{color:var(--brand)}
.ci-card .sub{font-size:15px;color:var(--ink-3);margin-top:3px}
.form-card{background:#fff;border:1px solid var(--line);border-radius:24px;padding:clamp(28px,4vw,44px);box-shadow:var(--shadow-lg)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}
.field label{font-size:14px;font-weight:600;color:var(--ink-2)}
.field label .req{color:var(--warn)}
.field input,.field textarea,.field select{font-family:inherit;font-size:16px;color:var(--ink);background:var(--paper);border:1px solid var(--line);border-radius:13px;padding:14px 16px;transition:border-color .2s,background .2s,box-shadow .2s;width:100%}
.field textarea{resize:vertical;min-height:130px}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--brand);background:#fff;box-shadow:0 0 0 4px rgba(74,119,199,.12)}
.field input::placeholder,.field textarea::placeholder{color:var(--ink-3);opacity:.7}
.form-consent{display:flex;gap:12px;align-items:flex-start;font-size:14px;color:var(--ink-3);line-height:1.5;margin:4px 0 22px}
.form-consent input{flex:0 0 20px;width:20px;height:20px;margin-top:1px;accent-color:var(--brand)}
.form-consent a{color:var(--brand);font-weight:600}
.form-card .btn{width:100%;justify-content:center}
.form-note{margin-top:16px;font-size:14px;color:var(--ink-3);text-align:center}
.form-ok{display:none;text-align:center;padding:20px 0}
.form-ok.show{display:block}
.form-ok .ic{width:64px;height:64px;border-radius:50%;background:rgba(25,182,138,.12);display:flex;align-items:center;justify-content:center;margin:0 auto 18px}
.form-ok .ic svg{width:32px;height:32px;stroke:var(--good);stroke-width:2.6;fill:none}
.form-ok h3{font-size:24px;font-weight:800;color:var(--ink);margin-bottom:10px}
.form-ok p{color:var(--ink-2);font-size:17px}
.map-band{display:block;text-decoration:none;border-radius:var(--r);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);height:340px;position:relative;background:linear-gradient(135deg,#EAF1FA,#D7E7F2);transition:transform .25s,box-shadow .25s}
.map-band:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.map-band .map-cta{display:inline-flex;align-items:center;gap:8px;margin-top:14px;font-weight:600;font-size:15px;color:var(--brand);background:#fff;border:1px solid var(--line);padding:9px 18px;border-radius:999px;transition:background .2s}
.map-band:hover .map-cta{background:var(--paper)}
.map-band .ov{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--brand-deep)}
.map-band .ov svg{width:50px;height:50px;stroke:var(--brand);fill:none;stroke-width:1.6}
.map-band .ov b{font-size:20px;font-weight:700}
.map-band .ov span{font-size:15px;color:var(--ink-3)}
@media (max-width:960px){.contact-grid{grid-template-columns:1fr;gap:32px}}
@media (max-width:560px){.form-row{grid-template-columns:1fr}}

/* =========================================================================
   v1.2 — dropdown menu, mobilní optimalizace, opravy přesahu
   ========================================================================= */

/* žádné vodorovné posouvání (backstop; samotné přetékající prvky řešíme níže) */
html{overflow-x:clip}
img,svg,iframe,video{max-width:100%}

/* ---- Dropdown „Služby" ---- */
.nav-item{position:relative;display:flex;align-items:center}
.nav-item .nav-parent{display:inline-flex;align-items:center;gap:6px;font-size:16px;font-weight:500;color:var(--ink-2);padding:10px 14px;border-radius:10px;transition:background .2s,color .2s}
.nav-item .nav-parent:hover{background:var(--paper);color:var(--brand-deep)}
.nav-item .nav-parent.active{color:var(--brand);font-weight:600}
.nav-parent .caret{width:15px;height:15px;transition:transform .25s}
.nav-item:hover .nav-parent .caret{transform:rotate(180deg)}
.sub-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px;color:var(--ink-2)}
.sub-toggle svg{width:20px;height:20px;transition:transform .25s}
.subnav{position:absolute;top:calc(100% + 6px);left:0;min-width:300px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-lg);padding:10px;display:flex;flex-direction:column;gap:2px;opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity .2s,transform .2s,visibility .2s;z-index:60}
.nav-item:hover .subnav{opacity:1;visibility:visible;transform:translateY(0)}
.subnav a{padding:11px 14px;border-radius:9px;font-size:15px;font-weight:500;color:var(--ink-2);white-space:nowrap}
.subnav a:hover{background:var(--paper);color:var(--brand-deep)}

/* ---- Google mapa (iframe) na Kontaktu ---- */
.map-embed{border-radius:var(--r);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);line-height:0}
.map-embed iframe{display:block;width:100%;height:360px;border:0}

/* =================== MOBIL ≤ 960px =================== */
@media (max-width:960px){
  /* mobilní menu — položky na střed (bod 1) */
  .nav-links{text-align:center}
  .nav-links a{text-align:center}
  /* dropdown jako rozbalovací sekce */
  .nav-item{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;width:100%}
  .nav-item .nav-parent{flex:0 1 auto;font-size:18px;padding:14px 12px}
  .sub-toggle{display:inline-flex;align-items:center}
  .subnav{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;border-radius:0;padding:0 0 8px;min-width:0;width:100%;display:none;background:transparent}
  .has-sub.open .subnav{display:flex}
  .has-sub.open .sub-toggle svg{transform:rotate(180deg)}
  .nav-item:hover .nav-parent .caret{transform:none}
  .nav-parent .caret{display:none}
  .subnav a{text-align:center;font-size:16px;padding:11px 12px;color:var(--ink-3)}
}

/* =================== MOBIL ≤ 600px =================== */
@media (max-width:600px){
  /* (bod 5) zkrotit pevné šířky a nezalamitelné nadpisy → konec přesahu */
  .head-block h1,.head-block h2,.head-block p,.hero h1,.section h2,.lead,.case-hero h1{
    width:auto !important;max-width:100% !important;white-space:normal !important;
  }
  .hero h1{font-size:clamp(32px,8.5vw,46px) !important}
  .stat .n span[style]{font-size:42px !important}

  /* (bod 2) tlačítka na plnou šířku, text na střed */
  .btn{width:100%;justify-content:center}
  .hero-cta{flex-direction:column;align-items:stretch}
  .nav-cta{width:100%}
  /* výjimky — odkazy, které nemají být plné */
  .case-nav .btn,.crumb .btn{width:auto}

  /* (bod 3) statistiky na úvodu — na střed + víc vzduchu */
  .grid.g4{gap:34px}
  .stat{text-align:center;padding:6px 0}
  .section.tight{padding-top:clamp(44px,11vw,72px);padding-bottom:clamp(44px,11vw,72px)}

  /* (bod 7) „Služby na klíč" — odrážky pod sebe */
  .svc-tags{grid-template-columns:1fr !important}

  /* (bod 10) navigace mezi referencemi — karty pod sebou, na střed */
  .case-nav{flex-direction:column;gap:12px}
  .case-nav a{justify-content:center;background:#fff;border:1px solid var(--line);border-radius:14px;padding:15px 18px;box-shadow:var(--shadow);width:100%}
  .case-nav a:hover{border-color:rgba(74,119,199,.4);box-shadow:var(--shadow-lg)}

  /* (bod 4) patička — na střed a přehledně */
  .foot-grid{grid-template-columns:1fr;text-align:center;gap:30px}
  .foot .brand{justify-content:center}
  .foot ul{align-items:center}
  .foot-contact{align-items:center}
  .foot-social,.foot-social.in-contact{justify-content:center}
  .foot-bottom{flex-direction:column;align-items:center;text-align:center;gap:8px}

  .map-embed iframe{height:300px}
}

/* =========================================================================
   v1.3 — opravy: CTA hover, boční okraj, čísla kroků, patička, logo
   ========================================================================= */

/* (1) CTA tlačítko v navigaci — čitelný hover (zachovat gradient, ne bílá na bílé) */
.nav-links a.nav-cta:hover{color:#fff;background:linear-gradient(135deg,#2A2566 0%,#3F4FA0 100%);box-shadow:0 20px 40px -14px rgba(74,119,199,.7)}

/* odkaz v patičkovém copyrightu */
.foot-bottom a{color:rgba(255,255,255,.6)}
.foot-bottom a:hover{color:var(--brand-aqua-2)}

/* (2) obsah bez .wrap (článek) dostane boční okraj i na tabletu */
@media (max-width:760px){
  .article{padding-left:20px;padding-right:20px}
}

@media (max-width:600px){
  /* (2) garantovaný boční okraj na celém webu — nic se nedotýká krajů */
  .wrap{padding-left:18px;padding-right:18px}
  .article{padding-left:18px;padding-right:18px}

  /* (3) čísla kroků (karty) zarovnat doleva; jen horní statistiky zůstávají na střed */
  .card{text-align:left}
  .card .stat{text-align:left}
  .stat-strip .s{text-align:center}

  /* (4) patička: „Web" a „Více" vedle sebe, logo a kontakt přes celou šířku */
  .foot-grid{grid-template-columns:1fr 1fr;text-align:center;gap:28px 18px}
  .foot-grid>div:first-child{grid-column:1 / -1}
  .foot-grid>div:last-child{grid-column:1 / -1}

  /* (7) logo v patičce o 50 % větší */
  .foot .brand-logo{height:64px}
}

/* v1.5 — fotka na „O nás" v poměru 4:3 */
.aside-photo{aspect-ratio:4/3}
@media (max-width:960px){ .aside-photo{aspect-ratio:4/3} }

/* v1.5.2 — nadpis na Kontaktu na jeden řádek (mobil zalamuje dle pravidla výše) */
.page-kontakt .head-block{max-width:1080px !important}
.page-kontakt .head-block h1{white-space:nowrap}

/* v1.6 — fotogalerie referencí + lightbox */
.gal{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.gal-item{display:block;border-radius:16px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);aspect-ratio:4/3;cursor:zoom-in;background:var(--paper-2)}
.gal-item img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.gal-item:hover img{transform:scale(1.05)}
@media (max-width:760px){ .gal{grid-template-columns:1fr 1fr;gap:12px} }
@media (max-width:480px){ .gal{grid-template-columns:1fr} }

.hv-lb{position:fixed;inset:0;background:rgba(15,18,48,.88);display:none;align-items:center;justify-content:center;z-index:200;padding:24px;cursor:zoom-out}
.hv-lb.open{display:flex}
.hv-lb img{max-width:100%;max-height:100%;border-radius:12px;box-shadow:var(--shadow-lg)}
.hv-lb .hv-lb-close{position:absolute;top:18px;right:22px;color:#fff;font-size:34px;line-height:1;font-weight:300;cursor:pointer;opacity:.8}
.hv-lb .hv-lb-close:hover{opacity:1}

/* v1.6.2 — KPI v detailu referencí: přiměřená velikost i pro delší textové hodnoty */
.kpi .n{font-size:clamp(30px,3.4vw,42px);line-height:1.12}
.kpi .l{margin-top:12px}
@media (max-width:560px){ .kpi .n{font-size:clamp(28px,8vw,38px)} }

/* v1.6.8 — badge ve fázích: zarovnané (stejný sloupec) + vodorovný padding */
.phase{grid-template-columns:220px 1fr}
.phase .tag{padding:10px 20px;justify-self:start;min-width:0}
@media (max-width:960px){
  .phase{grid-template-columns:1fr}
  .phase .tag{padding:10px 20px;justify-self:start;width:max-content;min-width:0}
}

/* v1.6.9 — poloviční mezera nad fotogalerií referencí */
.hv-gallery-sec{padding-top:clamp(32px,4.5vw,60px)}
.section:has(+ .hv-gallery-sec){padding-bottom:clamp(32px,4.5vw,60px)}
