
:root{--ink:#15171C;--ink-2:#2A2E37;--graphite:#1A1D24;--concrete:#F3F4F6;--line:#E4E6EB;--muted:#5C616C;--white:#fff;--red:#C8312B;--red-2:#E0473F;--red-ink:#9E2621;--maxw:1180px;--r:14px}
*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}
body{font-family:'Manrope',system-ui,Arial,sans-serif;color:var(--ink);background:#fff;line-height:1.55;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
h1,h2,h3,h4{line-height:1.1;letter-spacing:-.02em;font-weight:800}
.eyebrow{font-size:.78rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--red-2)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;font-weight:700;font-size:.95rem;padding:.85rem 1.4rem;border-radius:10px;border:1.5px solid transparent;transition:.18s;cursor:pointer;white-space:nowrap}
.btn i{font-size:.9em;line-height:1}
.btn-red{background:var(--red);color:#fff}.btn-red:hover{background:var(--red-ink)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.42)}.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.08)}
.btn-out{background:#fff;color:var(--ink);border-color:var(--line)}.btn-out:hover{border-color:var(--ink)}
.lede{color:var(--muted);font-size:1.05rem}
section{padding:80px 0}
.bar{display:inline-block;width:48px;height:3px;background:var(--red);margin-bottom:20px;border-radius:2px}
/* icons: always centered */
.fa-solid,.fa-brands,.fa-regular{line-height:1;vertical-align:middle}
/* HEADER */
header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.97);backdrop-filter:saturate(1.4) blur(8px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px;gap:1rem}
.logo svg{height:42px;width:auto;display:block}
.menu{display:flex;gap:1.5rem;font-weight:600;font-size:.95rem}
.menu a{color:var(--ink-2);padding:.3rem 0;border-bottom:2px solid transparent}
.menu a:hover{color:var(--ink);border-color:var(--red)}
.nav-cta{display:flex;align-items:center;gap:1rem}
.nav-tel{display:flex;align-items:center;gap:.5rem;font-weight:800;color:var(--ink)}.nav-tel i{color:var(--red)}
.burger{display:none;background:none;border:0;cursor:pointer;font-size:1.5rem;color:var(--ink)}
.mmenu{display:none;flex-direction:column;border-top:1px solid var(--line);background:#fff}
.mmenu a{padding:14px 22px;border-bottom:1px solid var(--line);font-weight:600}
body.navopen .mmenu{display:flex}
/* HERO */
.hero{position:relative;color:#fff;overflow:hidden;background:#0e1014;padding:0}
.hero-bg{position:absolute;inset:0;background-image:linear-gradient(90deg,rgba(10,12,16,.94) 0%,rgba(10,12,16,.78) 45%,rgba(10,12,16,.35) 100%),url('/images/hero.jpg');background-size:cover;background-position:center}
.hero-inner{position:relative;padding:98px 0 78px}
.hero h1{font-size:clamp(2.3rem,6vw,4rem);margin:.6rem 0 1.1rem;max-width:16ch}
.hero p.sub{max-width:54ch;color:#C9CDD6;font-size:1.12rem}
.hero-ctas{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:2rem}
.acute{display:inline-flex;align-items:center;gap:.55rem;background:rgba(224,71,63,.15);border:1.5px solid rgba(224,71,63,.55);color:#fff;font-weight:700;padding:.85rem 1.3rem;border-radius:10px}
.acute i{color:var(--red-2)}
.trust{display:flex;flex-wrap:wrap;gap:1.6rem 2rem;margin-top:2.6rem;padding-top:1.8rem;border-top:1px solid rgba(255,255,255,.14)}
.trust .t{display:flex;align-items:center;gap:.6rem;font-size:.92rem;color:#E7E9EE}
.trust .t i{color:var(--red-2);font-size:1.15rem}.trust .t b{font-weight:800}
/* heads */
.shead{text-align:center;max-width:62ch;margin:0 auto 46px}
.shead h2{font-size:clamp(1.9rem,4vw,2.7rem)}.shead p{margin-top:.8rem}
/* router */
.cards3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.ncard{border:1px solid var(--line);border-radius:var(--r);padding:30px;background:#fff;transition:.2s}
.ncard:hover{border-color:var(--ink);box-shadow:0 16px 44px -24px rgba(0,0,0,.45);transform:translateY(-3px)}
.ncard .ic{width:48px;height:48px;border-radius:11px;display:flex;align-items:center;justify-content:center;background:#FBE9E8;color:var(--red);font-size:1.2rem;margin-bottom:18px}
.ncard h3{font-size:1.24rem;margin-bottom:.5rem}.ncard p{color:var(--muted);font-size:.97rem;margin-bottom:1.1rem}
.ncard a{font-weight:700;color:var(--red);display:inline-flex;align-items:center;gap:.45rem;font-size:.95rem}
/* services */
.svc{background:var(--concrete)}
.grid-svc{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.scard{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:.2s;display:flex;flex-direction:column}
.scard:hover{transform:translateY(-3px);box-shadow:0 16px 44px -26px rgba(0,0,0,.45)}
.scard .ph{position:relative;aspect-ratio:16/10;overflow:hidden}
.scard .ph img{width:100%;height:100%;object-fit:cover;transition:.4s}
.scard:hover .ph img{transform:scale(1.05)}
.scard .badge{position:absolute;left:18px;top:-23px;z-index:3;width:46px;height:46px;border-radius:50%;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.05rem;box-shadow:0 8px 20px -6px rgba(200,49,43,.6)}
.scard .badge i{line-height:1}
.scard .body{padding:34px 24px 26px;position:relative}
.scard h3{font-size:1.15rem;margin-bottom:.45rem}.scard p{color:var(--muted);font-size:.93rem;margin-bottom:1rem}
.scard .more{font-weight:700;color:var(--red);font-size:.9rem;display:inline-flex;align-items:center;gap:.4rem}
/* why */
.why{background:var(--graphite);color:#fff}
.why .row{display:grid;grid-template-columns:1fr 1.05fr;gap:54px;align-items:center}
.why .imgwrap{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:4/5}
.why .imgwrap img{width:100%;height:100%;object-fit:cover}
.why .badge{position:absolute;left:0;bottom:0;background:var(--red);padding:18px 22px;border-top-right-radius:14px}
.why .badge b{font-size:2.3rem;line-height:1;display:block;font-weight:800}.why .badge span{font-size:.74rem;font-weight:600;opacity:.95}
.why h2{font-size:clamp(1.8rem,4vw,2.5rem);margin:.6rem 0 .8rem}
.why .lead{color:#C5C9D2;max-width:46ch;margin-bottom:1.6rem}
.why .feats{display:grid;grid-template-columns:1fr 1fr;gap:22px 30px}
.feat{display:flex;gap:.85rem}.feat i{color:var(--red-2);font-size:1.25rem;line-height:1;margin-top:3px}
.feat h4{font-size:1rem;margin-bottom:.2rem}.feat p{font-size:.87rem;color:#AfB4bf}
/* realizace */
.real .head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:32px;gap:1rem;flex-wrap:wrap}
.real h2{font-size:clamp(1.9rem,4vw,2.7rem)}
.real .all{font-weight:700;color:var(--red);display:inline-flex;align-items:center;gap:.45rem;white-space:nowrap}
.gal{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.gi{position:relative;border-radius:12px;overflow:hidden;aspect-ratio:3/4;cursor:pointer}
.gi img{width:100%;height:100%;object-fit:cover;transition:.4s}.gi:hover img{transform:scale(1.06)}
.gi .cap{position:absolute;left:0;right:0;bottom:0;padding:38px 16px 14px;background:linear-gradient(transparent,rgba(0,0,0,.82));color:#fff}
.gi .cap b{font-size:.96rem;display:block}.gi .cap span{font-size:.78rem;opacity:.85}
/* process */
.proc{background:var(--concrete)}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.step{padding-top:18px;border-top:3px solid var(--red)}
.step .n{font-size:.8rem;font-weight:800;color:var(--red);letter-spacing:.1em}
.step h4{font-size:1.1rem;margin:.45rem 0 .35rem}.step p{color:var(--muted);font-size:.92rem}
/* about */
.about .row{display:grid;grid-template-columns:1fr 1.05fr;gap:48px;align-items:center}
.about .ph{border-radius:var(--r);overflow:hidden;aspect-ratio:5/4}.about .ph img{width:100%;height:100%;object-fit:cover}
.about h2{font-size:clamp(1.8rem,4vw,2.4rem);margin:.6rem 0 1.1rem}.about p{color:var(--muted);margin-bottom:1rem}
.about .sig{font-weight:800;color:var(--ink);margin-top:1.2rem}.about .sig span{display:block;font-weight:600;color:var(--muted);font-size:.9rem}
/* faq */
.faq h2{font-size:clamp(1.9rem,4vw,2.7rem);margin-bottom:30px;text-align:center}
.faq .list{max-width:840px;margin:0 auto}
details{border-bottom:1px solid var(--line)}
summary{cursor:pointer;list-style:none;font-weight:700;font-size:1.05rem;padding:18px 0;display:flex;justify-content:space-between;gap:1rem;align-items:center}
summary::-webkit-details-marker{display:none}summary i{flex:0 0 auto;color:var(--red);transition:.2s;line-height:1}
details[open] summary i{transform:rotate(45deg)}details p{color:var(--muted);padding:0 0 18px;max-width:72ch}
/* final */
.final{background:var(--red);color:#fff;text-align:center}
.final h2{font-size:clamp(1.9rem,4vw,2.7rem);margin-bottom:1rem}
.final p{max-width:56ch;margin:0 auto 1.8rem;color:#FFE3E1;font-size:1.08rem}
.final .ctas{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap}
.final .btn-out{background:#fff;color:var(--red-ink);border-color:#fff}.final .btn-ghost{border-color:rgba(255,255,255,.6)}
/* map */
.mapband{display:grid;grid-template-columns:1.6fr 1fr;background:var(--ink)}
.mapband iframe{width:100%;height:100%;border:0;min-height:360px;display:block;filter:grayscale(.15) contrast(1.05)}
.findus{color:#fff;padding:46px}.findus h3{font-size:1.5rem;margin:.6rem 0 1rem}
.findus address{font-style:normal;color:#C9CDD6;line-height:1.8;margin-bottom:1.4rem}.findus .ll{display:flex;gap:.7rem;flex-wrap:wrap}
/* footer */
footer{background:#0e1014;color:#C9CDD6;padding:62px 0 26px}
.fgrid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.1fr;gap:36px}
footer .logo svg{height:40px}.ftag{margin:16px 0;font-size:.92rem;max-width:34ch}
.fcol h4{color:#fff;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:14px}
.fcol a,.fcol p{display:block;font-size:.92rem;padding:.26rem 0;color:#AfB4bf}.fcol a:hover{color:#fff}
.fsoc{display:flex;gap:.6rem;margin-top:14px}.fsoc a{width:36px;height:36px;border-radius:9px;border:1px solid rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;color:#C9CDD6}.fsoc a:hover{background:var(--red);border-color:var(--red);color:#fff}
.fbot{border-top:1px solid rgba(255,255,255,.1);margin-top:38px;padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-size:.82rem;color:#7d828c}.fbot a{color:#AfB4bf}
.sticky{display:none}
/* ARTICLE pages */
.subhero{background:var(--graphite);color:#fff;padding:56px 0 48px}
.crumb{font-size:.82rem;color:#AfB4bf;margin-bottom:14px}.crumb a{color:#AfB4bf}.crumb a:hover{color:#fff}
.subhero h1{font-size:clamp(2rem,4.5vw,3rem);max-width:20ch}
.subhero p{color:#C9CDD6;max-width:60ch;margin-top:14px;font-size:1.08rem}
.article .row{display:grid;grid-template-columns:1.6fr .9fr;gap:48px;align-items:start}
.article .photo{border-radius:var(--r);overflow:hidden;position:sticky;top:96px}
.article .photo img{width:100%;display:block}
.prose h2{font-size:1.5rem;margin:1.6rem 0 .7rem}.prose p{color:#3b3f47;margin-bottom:1rem}
.prose ul{list-style:none;margin:.4rem 0 1.2rem}
.prose li{position:relative;padding-left:30px;margin-bottom:.55rem;color:#3b3f47}
.prose li:before{content:"\f00c";font-family:"Font Awesome 6 Free";font-weight:900;color:var(--red);position:absolute;left:0;top:2px;font-size:.85rem}
.aside{background:var(--concrete);border-radius:var(--r);padding:26px}
.aside h3{font-size:1.1rem;margin-bottom:.5rem}.aside p{color:var(--muted);font-size:.94rem;margin-bottom:1rem}
.aside .btn{width:100%}
.related{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}
.related a{font-size:.82rem;font-weight:600;border:1px solid var(--line);border-radius:999px;padding:.35rem .8rem;color:var(--ink-2);background:#fff}
.related a:hover{border-color:var(--red);color:var(--red)}
/* gallery page */
.ggrid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.lb{position:fixed;inset:0;background:rgba(8,9,12,.94);display:none;align-items:center;justify-content:center;z-index:100}
.lb.open{display:flex}.lb img{max-width:92vw;max-height:86vh;border-radius:8px}
.lb .x,.lb .nav-b{position:absolute;background:rgba(255,255,255,.12);color:#fff;border:0;width:48px;height:48px;border-radius:50%;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center}
.lb .x{top:18px;right:18px}.lb .prev{left:18px;top:50%;transform:translateY(-50%)}.lb .next{right:18px;top:50%;transform:translateY(-50%)}
.lb .x:hover,.lb .nav-b:hover{background:var(--red)}
/* form */
.formwrap{display:grid;grid-template-columns:1.3fr .9fr;gap:40px;align-items:start}
.fld{margin-bottom:16px;position:relative}
.fld label{display:block;font-weight:600;font-size:.9rem;margin-bottom:6px}
.fld input,.fld select,.fld textarea{width:100%;padding:.8rem .9rem;border:1.5px solid var(--line);border-radius:10px;font:inherit;background:#fff}
.fld input:focus,.fld select:focus,.fld textarea:focus{outline:none;border-color:var(--red)}
.fld textarea{min-height:120px;resize:vertical}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.hp{position:absolute;left:-9999px;opacity:0;height:0;width:0}
.sugg{position:absolute;left:0;right:0;top:100%;background:#fff;border:1px solid var(--line);border-radius:10px;box-shadow:0 14px 40px -18px rgba(0,0,0,.4);z-index:20;max-height:240px;overflow:auto;display:none}
.sugg div{padding:.6rem .9rem;cursor:pointer;font-size:.92rem}.sugg div:hover{background:var(--concrete)}
.gdpr{display:flex;gap:.6rem;align-items:flex-start;font-size:.88rem;color:var(--muted)}
.gdpr input{width:auto;margin-top:3px}
.err{color:var(--red-ink);font-size:.85rem;margin-top:6px;display:none}
.formnote{background:var(--concrete);border-radius:var(--r);padding:26px}
.formnote h3{margin-bottom:.6rem}.formnote p,.formnote a{color:var(--muted);font-size:.95rem}.formnote a{color:var(--red);font-weight:700}
.formnote .line{display:flex;gap:.6rem;align-items:center;margin:.5rem 0;color:var(--ink)}
.formnote .line i{color:var(--red);width:20px;text-align:center}
.okbox{background:#EAF7EE;border:1px solid #BfE6C7;color:#1c6b35;border-radius:10px;padding:16px;display:none;margin-bottom:16px}
.okbox.show{display:block}
@media(max-width:980px){
 .cards3,.grid-svc,.steps{grid-template-columns:repeat(2,1fr)}.gal,.ggrid{grid-template-columns:repeat(2,1fr)}
 .why .row,.about .row,.mapband,.fgrid,.article .row,.formwrap{grid-template-columns:1fr}
 .about .ph{order:-1}.article .photo{position:static}.menu,.nav-tel{display:none}.burger{display:block}.findus{padding:34px 22px}
}
@media(max-width:560px){section{padding:56px 0}.cards3,.grid-svc,.gal,.ggrid,.steps,.why .feats,.row2{grid-template-columns:1fr}
 .hero-inner{padding:64px 0 54px}.sticky{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:60;background:#fff;border-top:1px solid var(--line);padding:10px;gap:10px}.sticky a{flex:1}body{padding-bottom:72px}}

.menu .has-dd{position:relative}
.menu .has-dd>a{display:inline-flex;align-items:center;gap:.35rem}
.dd{position:absolute;top:100%;left:0;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 18px 48px -22px rgba(0,0,0,.5);min-width:244px;padding:8px;display:none;flex-direction:column}
.menu .has-dd:hover .dd{display:flex}
.dd a{padding:.6rem .8rem;border:0;border-radius:8px;font-size:.92rem;color:var(--ink-2)}
.dd a:hover{background:var(--concrete);color:var(--red)}
.mmenu .msub{padding-left:38px;color:var(--muted);font-weight:500;font-size:.92rem}

.scard .badge .bicon{width:22px;height:22px;display:block}
