/* ============================================================
   HIGH GROUP — design systém
   Tmavé pozadí · luxusní · velmi seriózní
   Paleta: #FFFF00 / #000000 / #5F5F5F / #D8D8D8
   ============================================================ */

:root{
  --black:#000000;
  --bg:#000000;
  --panel:#0b0b0b;
  --panel-2:#111111;
  --card:#161616;
  --line:rgba(255,255,255,.10);
  --line-strong:rgba(255,255,255,.18);
  --yellow:#FFFF00;
  --yellow-dim:#d6d600;
  --gray:#5F5F5F;
  --text:#D8D8D8;
  --text-strong:#ffffff;
  --muted:#8a8a8a;

  --font-display:"Figtree",-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;
  --font-body:"Hanken Grotesk",-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;

  --maxw:1200px;
  --gutter:clamp(20px,5vw,48px);
  --radius:4px;
  --header-h:84px;

  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;scroll-padding-top:var(--header-h)}
body{
  margin:0;background:var(--bg);color:var(--text);
  font-family:var(--font-body);font-size:17px;line-height:1.7;
  font-weight:400;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{margin:0;padding:0;list-style:none}
h1,h2,h3,h4{font-family:var(--font-display);color:var(--text-strong);line-height:1.05;margin:0;font-weight:800;letter-spacing:-.01em}
p{margin:0 0 1em}
strong{color:var(--text-strong);font-weight:700}
::selection{background:var(--yellow);color:#000}

/* ---------- Tenký scrollbar ---------- */
html{scrollbar-width:thin;scrollbar-color:#3a3a3a transparent}
*{scrollbar-width:thin;scrollbar-color:#3a3a3a transparent}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:#0a0a0a}
::-webkit-scrollbar-thumb{background:#3a3a3a;border-radius:10px;border:2px solid #0a0a0a}
::-webkit-scrollbar-thumb:hover{background:var(--yellow)}

.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.visually-hidden,.skip-link:not(:focus){position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.skip-link{position:fixed;top:10px;left:10px;z-index:200;background:var(--yellow);color:#000;padding:10px 16px;border-radius:var(--radius);font-weight:700}

/* ---------- Typo helpers ---------- */
.eyebrow{
  display:inline-block;font-family:var(--font-display);font-weight:700;
  font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--yellow);
  margin-bottom:14px;
}
.sect-head{margin-bottom:clamp(28px,4vw,48px);max-width:760px}
.sect-head--center{margin-inline:auto;text-align:center}
.sect-title{
  font-size:clamp(1.9rem,4.6vw,3.25rem);text-transform:uppercase;font-weight:900;
  color:var(--text-strong);position:relative;padding-bottom:.5em;letter-spacing:-.015em;
}
/* odstup obsahu (lead, odstavce) od žluté linky pod nadpisem */
.sect-title:not(:last-child){margin-bottom:16px}
.sect-title::after{
  content:"";position:absolute;left:0;bottom:0;width:90px;height:4px;background:var(--yellow);
}
.sect-head--center .sect-title::after{left:50%;transform:translateX(-50%)}
.lead{font-size:clamp(1.05rem,1.6vw,1.22rem);color:var(--text);font-weight:500}
.text-yellow{color:var(--yellow)}

/* ---------- Buttons ---------- */
.btn{
  --b:var(--yellow);
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:var(--font-display);font-weight:800;font-size:.95rem;letter-spacing:.02em;
  text-transform:uppercase;padding:15px 30px;border-radius:var(--radius);
  border:2px solid var(--b);transition:.25s var(--ease);cursor:pointer;line-height:1;white-space:nowrap;
}
.btn--primary{background:var(--yellow);color:#000}
.btn--primary:hover{background:#fff;border-color:#fff;transform:translateY(-2px)}
.btn--ghost{background:transparent;color:var(--yellow)}
.btn--ghost:hover{background:var(--yellow);color:#000;transform:translateY(-2px)}
.btn--sm{padding:11px 20px;font-size:.82rem}
.btn--dark{background:#000;color:#fff;border-color:#000}
.btn--dark:hover{background:#111;border-color:#111}

/* ---------- Section rhythm ---------- */
.section{padding-block:clamp(64px,9vw,120px);position:relative}
.section--tight{padding-block:clamp(48px,6vw,80px)}
.section--panel{background:var(--panel)}
.section--line{border-top:1px solid var(--line)}

/* Lion-head watermark pattern */
.pattern-bg{position:relative}
.pattern-bg::before{
  content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:url('/assets/img/brand/pattern-tile.png');
  background-size:170px;opacity:.5;
  -webkit-mask-image:linear-gradient(180deg,transparent,#000 25%,#000 75%,transparent);
          mask-image:linear-gradient(180deg,transparent,#000 25%,#000 75%,transparent);
}
.pattern-bg>*{position:relative;z-index:1}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;height:var(--header-h);
  display:flex;align-items:center;
  background:rgba(0,0,0,.55);backdrop-filter:blur(10px);
  border-bottom:1px solid transparent;transition:.3s var(--ease);
}
.site-header.is-scrolled{background:rgba(0,0,0,.92);border-bottom-color:var(--line);height:72px}
.site-header__inner{display:flex;align-items:center;gap:28px;width:100%}
.site-header__logo img{width:auto;height:50px;transition:height .3s var(--ease)}
.site-header.is-scrolled .site-header__logo img{height:42px}

.main-nav{margin-left:auto;display:flex;align-items:center}
.nav-menu{display:flex;align-items:center;gap:6px}
.nav-menu__item>a:not(.btn){
  display:inline-flex;align-items:center;gap:6px;padding:10px 16px;
  font-family:var(--font-display);font-weight:700;font-size:.95rem;color:var(--text);
  text-transform:uppercase;letter-spacing:.04em;border-radius:var(--radius);transition:.2s;
}
.nav-menu__item>a:not(.btn):hover,.nav-menu__item>a:not(.btn).is-active{color:var(--yellow)}
.nav-menu__item>a.is-active{position:relative}
.caret{font-size:.7em;color:var(--yellow)}

.has-dropdown{position:relative}
.dropdown{
  position:absolute;top:calc(100% + 8px);left:0;min-width:300px;
  background:#0b0b0b;border:1px solid var(--line-strong);border-radius:6px;
  padding:8px;opacity:0;visibility:hidden;transform:translateY(8px);transition:.22s var(--ease);
  box-shadow:0 24px 60px rgba(0,0,0,.6);
}
.has-dropdown:hover .dropdown,.has-dropdown:focus-within .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown li a{display:flex;flex-direction:column;gap:2px;padding:12px 16px;border-radius:var(--radius);transition:.18s}
.dropdown li a strong{color:#fff;font-family:var(--font-display);text-transform:uppercase;letter-spacing:.04em;font-size:.92rem}
.dropdown li a span{color:var(--muted);font-size:.82rem}
.dropdown li a:hover,.dropdown li a.is-active{background:#161616}
.dropdown li a:hover strong,.dropdown li a.is-active strong{color:var(--yellow)}

.nav-menu__item--cta{margin-left:10px}

.site-header__phone{display:flex;flex-direction:column;align-items:flex-end;line-height:1.1;margin-left:6px}
.site-header__phone-label{font-family:var(--font-display);font-size:.62rem;letter-spacing:.18em;color:var(--yellow);font-weight:700}
.site-header__phone-num{font-family:var(--font-display);font-weight:800;font-size:1.05rem;color:#fff}
.site-header__phone:hover .site-header__phone-num{color:var(--yellow)}

.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:46px;height:46px;background:none;border:0;cursor:pointer;padding:0}
.nav-toggle span:not(.visually-hidden){display:block;width:26px;height:2px;background:#fff;transition:.3s var(--ease)}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  min-height:clamp(620px,84vh,900px);display:flex;align-items:center;position:relative;overflow:hidden;
  padding-top:var(--header-h);
}
.hero__bg{position:absolute;inset:0;z-index:0}
.hero__bg::before{
  content:"";position:absolute;inset:0;
  background-image:url('/assets/img/brand/pattern-tile.png');background-size:190px;opacity:.1;
}
.hero__bg::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(90% 90% at 80% 40%,rgba(255,255,0,.05),transparent 55%),
             linear-gradient(90deg,#000 35%,transparent 75%),
             radial-gradient(80% 80% at 50% 120%,rgba(0,0,0,.9),transparent);
}
/* lion banner, right side */
.hero__lion{
  position:absolute;top:50%;right:-3%;transform:translateY(-50%);z-index:0;
  height:min(108%,920px);width:auto;pointer-events:none;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 9%);
          mask-image:linear-gradient(90deg,transparent,#000 9%);
}
/* diagonal accent lines */
.hero__accent{position:absolute;right:0;bottom:0;width:38%;height:60%;z-index:0;opacity:.5;pointer-events:none;
  background:repeating-linear-gradient(125deg,transparent 0 38px,rgba(255,255,0,.08) 38px 40px);
  -webkit-mask-image:linear-gradient(135deg,transparent 40%,#000);mask-image:linear-gradient(135deg,transparent 40%,#000)}

.hero__inner{position:relative;z-index:1;width:100%;display:flex;align-items:center;justify-content:center}
.hero__content{max-width:600px;flex:1 1 auto}

/* HERO homepage — velké motto jako jediné sdělení, centrované (logo nese pouze hlavička) */
.page-home .hero__content{max-width:1020px;flex:0 1 auto;text-align:center}
.hero h1.hero__claim{
  font-size:clamp(2.2rem,5.8vw,5.2rem);font-weight:800;text-transform:none;letter-spacing:-.02em;
  line-height:1.08;margin:clamp(16px,2.4vw,26px) auto 0;max-width:17ch;
}
.hero__claim em{font-style:normal;color:var(--yellow)}
.page-home .hero__rule{margin:clamp(26px,3.4vw,38px) auto 0}
.hero__logo{width:min(280px,60vw);margin:0 auto clamp(22px,4vw,38px)}
.hero h1{
  font-size:clamp(2.8rem,7vw,5.6rem);text-transform:uppercase;color:#fff;font-weight:900;
  letter-spacing:-.02em;margin:0 0 .25em;line-height:.95;
}
.hero h1 em{font-style:normal;color:var(--yellow)}
.hero__rule{width:84px;height:5px;background:var(--yellow);margin:0 0 26px;border:0}
.hero__sub{font-size:clamp(1.1rem,1.9vw,1.4rem);color:var(--text);max-width:46ch;margin:0 0 clamp(28px,4vw,40px);font-weight:500}
.hero__actions{display:flex;gap:16px;flex-wrap:wrap}
.hero__scroll{
  position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:1;
  color:var(--muted);font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:10px;font-family:var(--font-display);font-weight:700;
  transition:color .25s var(--ease);
}
.hero__scroll:hover{color:var(--yellow)}
.hero__scroll::after{content:"";width:1px;height:42px;background:linear-gradient(var(--yellow),transparent);animation:scrollpulse 2s var(--ease) infinite}
@keyframes scrollpulse{0%,100%{opacity:.3;transform:scaleY(.7)}50%{opacity:1;transform:scaleY(1)}}
@media (max-width:860px){
  .hero{min-height:auto;padding-block:calc(var(--header-h) + 44px) 40px;text-align:center;
        flex-direction:column;align-items:stretch;justify-content:center}
  .hero__inner{flex-direction:column;align-items:stretch;gap:30px}
  .hero__content{max-width:none;margin-inline:auto}
  .hero__rule{margin-inline:auto}
  .hero__sub{margin-inline:auto}
  .hero__lion,.hero__accent{display:none}
  /* scroll cue jako statický řádek pod mottem */
  .hero__scroll{position:static;transform:none;align-self:center;margin-top:34px;font-size:.7rem;
                padding-inline:28px;line-height:1.7}
  .hero__scroll::after{height:30px}
}

/* ============================================================
   INTRO / quote (jednatel)
   ============================================================ */
.intro-quote{max-width:900px;margin-inline:auto;text-align:center}
.intro-quote blockquote{
  font-family:var(--font-display);font-weight:500;font-size:clamp(1.3rem,2.8vw,2rem);
  color:#fff;line-height:1.4;margin:0 0 28px;letter-spacing:-.01em;
}
.intro-quote blockquote b{color:var(--yellow);font-weight:700}
.intro-quote cite{font-style:normal;color:var(--muted);font-size:1rem}
.intro-quote cite strong{color:#fff;display:block;font-family:var(--font-display);text-transform:uppercase;letter-spacing:.08em;font-size:1.05rem;margin-bottom:2px}

/* ============================================================
   DIVISION TILES (homepage)
   ============================================================ */
.tiles{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(20px,2vw,28px)}
.tile{
  position:relative;display:flex;flex-direction:column;overflow:hidden;
  border:1px solid var(--line);border-radius:10px;background:var(--panel-2);
  transition:transform .35s var(--ease),border-color .35s var(--ease),box-shadow .35s var(--ease);
  isolation:isolate;
}
.tile:hover{border-color:rgba(255,255,0,.55);transform:translateY(-6px);box-shadow:0 22px 50px rgba(0,0,0,.55)}

/* Photo band on top — identical height for all → perfect alignment */
.tile__media{position:relative;aspect-ratio:22/9;display:grid;place-items:center;overflow:hidden;border-bottom:1px solid var(--line)}
.tile__photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:grayscale(.38) brightness(.52);transition:.6s var(--ease)}
.tile__media::after{content:"";position:absolute;inset:0;background:radial-gradient(125% 105% at 50% 35%,rgba(0,0,0,.12),rgba(0,0,0,.66))}
.tile:hover .tile__photo{filter:grayscale(0) brightness(.62);transform:scale(1.07)}
/* centered lockup, fixed height → all logos visually consistent */
.tile__logo{position:relative;z-index:1;height:128px;width:auto;max-width:88%;object-fit:contain;filter:drop-shadow(0 6px 22px rgba(0,0,0,.8));transition:transform .4s var(--ease)}
.tile:hover .tile__logo{transform:translateY(-3px)}

/* Solid content area — flex column so CTA pins to bottom and all align */
.tile__body{flex:1;display:flex;flex-direction:column;padding:clamp(22px,2.4vw,28px);padding-bottom:clamp(16px,1.9vw,20px)}
.tile__claim{color:#fff;font-family:var(--font-display);font-weight:700;font-size:clamp(1.05rem,1.25vw,1.2rem);margin-bottom:16px;line-height:1.25}
.tile__list{display:flex;flex-direction:column;gap:9px;margin:0 0 22px;flex:1}
.tile__list li{padding-left:20px;position:relative;color:var(--text);font-size:.92rem;line-height:1.45}
.tile__list li::before{content:"";position:absolute;left:0;top:.5em;width:9px;height:9px;background:var(--yellow);clip-path:polygon(0 0,100% 50%,0 100%)}
.tile__more{margin-top:auto;font-family:var(--font-display);font-weight:800;text-transform:uppercase;letter-spacing:.06em;font-size:.82rem;color:var(--yellow);display:inline-flex;align-items:center;gap:8px;padding-top:14px;border-top:1px solid var(--line)}
.tile__more::after{content:"→";transition:.25s;margin-left:auto}
.tile:hover .tile__more::after{transform:translateX(6px)}
.tile__link{position:absolute;inset:0;z-index:2;font-size:0;color:transparent}
@media (max-width:900px){.tile__media{aspect-ratio:16/9}}
@media (max-width:540px){.tiles{grid-template-columns:1fr}}

/* ============================================================
   STATS band
   ============================================================ */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,3vw,40px);text-align:center}
.stat{display:flex;flex-direction:column;align-items:center}
.stat__num{display:flex;align-items:flex-end;justify-content:center;min-height:clamp(2.2rem,5vw,3.4rem);
  font-family:var(--font-display);font-weight:900;font-size:clamp(2.2rem,5vw,3.4rem);color:var(--yellow);line-height:1}
.stat__num--code{font-size:clamp(1.6rem,3.3vw,2.3rem);white-space:nowrap;letter-spacing:.01em}
.stat__label{display:block;margin-top:8px;color:var(--text);font-size:.95rem;letter-spacing:.02em}

/* ============================================================
   SPLIT (division detail sections)
   ============================================================ */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,5vw,70px);align-items:center}
.split--rev .split__media{order:2}
.split__media{position:relative;border-radius:6px;overflow:hidden;align-self:stretch;min-height:340px}
.split__media img{width:100%;height:100%;object-fit:cover}
.split__media::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(0,0,0,.4),transparent 50%)}
.split__badge{position:absolute;right:18px;bottom:18px;z-index:2;height:74px;width:auto;filter:drop-shadow(0 4px 18px rgba(0,0,0,.7))}
.split__body p{margin-bottom:1.1em}

/* ============================================================
   BULLET LIST (yellow markers)
   ============================================================ */
.bullets{display:grid;gap:12px;margin:24px 0}
.bullets li{position:relative;padding-left:30px;color:var(--text)}
.bullets li::before{
  content:"";position:absolute;left:0;top:.55em;width:11px;height:11px;
  background:var(--yellow);clip-path:polygon(0 0,100% 50%,0 100%);
}
.bullets--cols{grid-template-columns:1fr 1fr;column-gap:36px}
.bullets-title{font-family:var(--font-display);font-weight:800;color:#fff;text-transform:uppercase;letter-spacing:.05em;font-size:.95rem;margin:6px 0 4px}

/* ============================================================
   FEATURE CARDS (services grid on division pages)
   ============================================================ */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}
.cards--3{grid-template-columns:repeat(3,1fr)}
@media (max-width:860px){.cards--3{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.cards--3{grid-template-columns:1fr}}
.card{background:var(--card);border:1px solid var(--line);border-radius:6px;padding:28px;transition:.3s var(--ease)}
.card:hover{border-color:rgba(255,255,0,.4);transform:translateY(-3px)}
.card h3{font-size:1.15rem;color:#fff;margin-bottom:10px;text-transform:uppercase;letter-spacing:.02em}
.card p{color:var(--text);font-size:.96rem;margin:0}
.card__icon{width:40px;height:40px;margin-bottom:16px;display:grid;place-items:center;color:var(--yellow);border:2px solid var(--yellow);border-radius:50%;font-weight:900;font-family:var(--font-display)}
.card--prose p{margin-bottom:1em}
.card--prose p:last-child{margin-bottom:0}
.card{display:flex;flex-direction:column;position:relative}
.card__more{display:inline-flex;align-items:center;gap:8px;margin-top:auto;padding-top:18px;color:var(--yellow);font-family:var(--font-display);font-weight:700;font-size:.85rem;text-transform:uppercase;letter-spacing:.08em}
/* celá karta klikací — odkaz se roztáhne přes kartu */
.card__more::after{content:"";position:absolute;inset:0}
.card:has(.card__more){cursor:pointer}
.card__more .ic{width:17px;height:17px;transition:transform .3s var(--ease)}
.card:hover .card__more .ic{transform:translateX(4px)}

/* ============================================================
   DETAILNÍ SLUŽBY (číslované řádky — divizní podstránky)
   ============================================================ */
.svc-list{border-top:1px solid var(--line);margin-top:10px}
.svc{display:grid;grid-template-columns:minmax(0,.85fr) minmax(0,1.15fr);gap:clamp(22px,4vw,70px);padding:clamp(30px,4.5vw,54px) 0;border-bottom:1px solid var(--line)}
.svc__head{display:flex;align-items:center;gap:20px}
.svc__icon{flex:none;width:54px;height:54px;border:2px solid var(--yellow);border-radius:14px;color:var(--yellow);display:grid;place-items:center;transition:.3s var(--ease)}
.svc__icon .ic{width:26px;height:26px}
.svc:hover .svc__icon{background:var(--yellow);color:#000}
.svc__title{font-size:clamp(1.2rem,1.9vw,1.45rem);line-height:1.3;color:#fff;text-transform:uppercase;letter-spacing:.02em;margin:0;text-wrap:balance}
.svc__body p{color:var(--text);margin-bottom:1em}
.svc__body p:last-child{margin-bottom:0}

/* ============================================================
   SVG ANIMACE DIVIZÍ (dekorativní scény, čistě CSS)
   ============================================================ */
.svganim{margin:6px auto 40px;max-width:720px}
.svganim svg{display:block;width:100%;height:auto}
.svganim figcaption{text-align:center;color:var(--muted);font-size:.85rem;margin-top:12px}

/* nadpis sekce 50 % + animace vedle něj */
.sect-split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,64px);align-items:center;margin-bottom:clamp(20px,3vw,36px)}
.sect-split .sect-head{margin-bottom:0}
.sect-split .svganim{margin:0;max-width:none}
@media (max-width:860px){.sect-split{grid-template-columns:1fr}}

/* --- Security: pochůzka SOK --- */
.sok-wall{stroke:#3d3d3d}
.sok-room{stroke:#2b2b2b}
.sok-route{stroke:rgba(255,255,0,.25);stroke-dasharray:3 8;animation:sok-march 1.4s linear infinite}
.sok-chip{stroke:#5F5F5F;animation:sok-flash 16s linear infinite}
.sok-ring{stroke:var(--yellow);opacity:0;transform-box:fill-box;transform-origin:center;animation:sok-ping 16s linear infinite}
.sok-guard{offset-path:path('M140 110h520v140H140z');offset-rotate:0deg;animation:sok-walk 16s linear infinite}
.sok-guard-halo{stroke:var(--yellow);opacity:.35;transform-box:fill-box;transform-origin:center;animation:sok-halo 1.6s ease-out infinite}
/* příchody strážného: 0 / 6.3 / 8 / 14.3 s (poměrné délky úseků trasy) */
.sok-ring--2,.sok-chip--2{animation-delay:6.3s}
.sok-ring--3,.sok-chip--3{animation-delay:8s}
.sok-ring--4,.sok-chip--4{animation-delay:14.3s}
@keyframes sok-walk{to{offset-distance:100%}}
@keyframes sok-march{to{stroke-dashoffset:-11}}
@keyframes sok-ping{0%{opacity:.85;transform:scale(.3)}8%{opacity:0;transform:scale(1.5)}100%{opacity:0;transform:scale(1.5)}}
@keyframes sok-flash{0%{stroke:var(--yellow);fill:rgba(255,255,0,.85)}7%{stroke:#5F5F5F;fill:rgba(255,255,0,0)}100%{stroke:#5F5F5F;fill:rgba(255,255,0,0)}}
@keyframes sok-halo{0%{opacity:.4;transform:scale(.55)}100%{opacity:0;transform:scale(1.25)}}
/* --- Technology: detekce → PCO → výjezd (12 s smyčka) --- */
.tech-ground,.tech-wall{stroke:#3d3d3d}
.tech-room{stroke:#2b2b2b}
.tech-cam-body{stroke:#5F5F5F}
.tech-cam{transform-box:fill-box;transform-origin:0% 50%;animation:tech-pan 5s ease-in-out infinite alternate}
.tech-fov{fill:rgba(255,255,0,.06);stroke:rgba(255,255,0,.14);stroke-width:1}
.tech-alert,.tech-ping,.tech-ok{stroke:var(--yellow);opacity:0;transform-box:fill-box;transform-origin:center;animation:sok-ping 12s linear infinite}
.tech-ping{animation-delay:2.9s}
.tech-ok{animation-delay:7.7s}
.tech-signal{stroke:rgba(255,255,0,.45);stroke-dasharray:5 9;animation:tech-send 12s linear infinite}
.tech-beacon{animation:tech-blink 2s ease-in-out infinite}
.tech-car{offset-path:path('M610 320H240');offset-rotate:0deg;animation:tech-drive 12s linear infinite}
.tech-car-halo{stroke:var(--yellow);opacity:.35;transform-box:fill-box;transform-origin:center;animation:sok-halo 1.6s ease-out infinite}
@keyframes tech-pan{from{transform:rotate(-8deg)}to{transform:rotate(10deg)}}
@keyframes tech-send{0%{opacity:0;stroke-dashoffset:0}4%{opacity:1}22%{opacity:1;stroke-dashoffset:-154}26%{opacity:0;stroke-dashoffset:-154}100%{opacity:0;stroke-dashoffset:-154}}
@keyframes tech-blink{0%,100%{opacity:.25}50%{opacity:1}}
@keyframes tech-drive{0%,32%{offset-distance:0%;opacity:0}36%{opacity:1}62%{offset-distance:100%;opacity:1}67%,100%{offset-distance:100%;opacity:0}}

/* --- Technology: radarový dohled (6 s otáčka) --- */
.rad-ring{stroke:#3d3d3d}
.rad-cross{stroke:#2b2b2b}
.rad-beam{fill:rgba(255,255,0,.10)}
.rad-hand{stroke:rgba(255,255,0,.55)}
.rad-sweep{transform-box:view-box;transform-origin:400px 185px;animation:rad-turn 6s linear infinite}
.rad-dot{opacity:.9}
.rad-blip{opacity:0;animation:rad-blink 6s linear infinite}
.rad-blip--1{animation-delay:1.85s}
.rad-blip--2{animation-delay:3.85s}
.rad-blip--3{animation-delay:5.3s}
@keyframes rad-turn{to{transform:rotate(360deg)}}
@keyframes rad-blink{0%{opacity:1}12%{opacity:.85}70%{opacity:0}100%{opacity:0}}

/* --- Technology: chytrá budova LOXONE (8 s cyklus) --- */
.lox-wall{stroke:#3d3d3d}
.lox-line{stroke:#2b2b2b;stroke-dasharray:3 7}
.lox-hub{stroke:var(--yellow)}
.lox-hub-ring{stroke:var(--yellow);opacity:0;transform-box:fill-box;transform-origin:center;animation:lox-pulse 2.5s linear infinite}
.lox-phone{stroke:#5F5F5F}
.lox-link{stroke:rgba(255,255,0,.35);stroke-dasharray:4 8;animation:sok-march 1.4s linear infinite}
.lox-dev{stroke:#5F5F5F;animation:lox-flash 8s linear infinite}
.lox-ring{stroke:var(--yellow);opacity:0;transform-box:fill-box;transform-origin:center;animation:lox-ping 8s linear infinite}
.lox-dev--2,.lox-ring--2{animation-delay:2s}
.lox-dev--3,.lox-ring--3{animation-delay:4s}
.lox-dev--4,.lox-ring--4{animation-delay:6s}
@keyframes lox-pulse{0%{opacity:.7;transform:scale(.5)}55%{opacity:0;transform:scale(1.5)}100%{opacity:0;transform:scale(1.5)}}
@keyframes lox-ping{0%{opacity:.8;transform:scale(.35)}12%{opacity:0;transform:scale(1.5)}100%{opacity:0;transform:scale(1.5)}}
@keyframes lox-flash{0%{stroke:#FFFF00}14%{stroke:#FFFF00}26%{stroke:#5F5F5F}100%{stroke:#5F5F5F}}

/* --- Cleaning: mytí okna (10 s smyčka) --- */
.cln-frame{stroke:#3d3d3d}
.cln-glass{stroke:rgba(255,255,255,.10);animation:cln-gleam 10s linear infinite}
.cln-shine{fill:rgba(255,255,170,.05);transform-box:fill-box;transform-origin:left center;animation:cln-reveal 10s linear infinite}
.cln-blade{stroke:var(--yellow)}
.cln-handle{stroke:#5F5F5F}
.cln-squeegee{animation:cln-wipe 10s ease-in-out infinite}
.cln-spark{opacity:0;transform-box:fill-box;transform-origin:center;animation:cln-pop 10s linear infinite}
.cln-spark--1{animation-delay:5s}
.cln-spark--2{animation-delay:6.2s}
.cln-spark--3{animation-delay:7.4s}
@keyframes cln-wipe{0%{transform:translateX(232px);opacity:0}5%{transform:translateX(232px);opacity:1}48%{transform:translateX(548px);opacity:1}54%{transform:translateX(548px);opacity:0}100%{transform:translateX(548px);opacity:0}}
@keyframes cln-reveal{0%,5%{transform:scaleX(.02);opacity:1}48%{transform:scaleX(.95);opacity:1}56%{transform:scaleX(1)}84%{transform:scaleX(1);opacity:1}96%,100%{transform:scaleX(1);opacity:0}}
@keyframes cln-gleam{0%,42%{opacity:.5}55%{opacity:1}84%{opacity:1}100%{opacity:.5}}
@keyframes cln-pop{0%{transform:scale(0) rotate(0deg);opacity:0}4%{transform:scale(1) rotate(25deg);opacity:.95}8%{transform:scale(.65) rotate(40deg);opacity:.5}11%,100%{transform:scale(0) rotate(45deg);opacity:0}}

/* --- Reality: od nabídky k prodeji (14 s smyčka) --- */
.rea-ground{stroke:#3d3d3d}
.rea-house{stroke:#D8D8D8;stroke-dasharray:1;animation:rea-draw 14s linear infinite}
.rea-light{fill:rgba(255,255,0,.28);opacity:0;animation:rea-lit 14s linear infinite}
.rea-light--2{animation-name:rea-lit2}
.rea-pin{animation:rea-drop 14s ease-out infinite}
.rea-tag{opacity:0;transform-box:fill-box;transform-origin:50% 100%;animation:rea-sold 14s ease-out infinite}
.rea-tag-post{stroke:#5F5F5F}
.rea-tag text{font-family:var(--font-display)}
@keyframes rea-draw{0%{stroke-dashoffset:1}26%,100%{stroke-dashoffset:0}}
@keyframes rea-drop{0%,30%{transform:translateY(-46px);opacity:0}36%{transform:translateY(5px);opacity:1}40%{transform:translateY(-3px)}44%,100%{transform:translateY(0);opacity:1}}
@keyframes rea-lit{0%,46%{opacity:0}50%,100%{opacity:1}}
@keyframes rea-lit2{0%,53%{opacity:0}57%,100%{opacity:1}}
@keyframes rea-sold{0%,62%{transform:scale(0);opacity:0}67%{transform:scale(1.07);opacity:1}70%,100%{transform:scale(1);opacity:1}}

/* --- Reality: správa pronájmů a úschova (12 s cyklus) --- */
.ext-ground,.ext-bld,.ext-safe{stroke:#3d3d3d}
.ext-win{stroke:#2b2b2b}
.ext-dial-base{stroke:#5F5F5F}
.ext-dial{stroke:var(--yellow);transform-box:fill-box;transform-origin:center;animation:ext-lock 12s ease-in-out infinite}
.ext-path{stroke:rgba(255,255,0,.25);stroke-dasharray:3 8;animation:sok-march 1.4s linear infinite}
.ext-lit{fill:rgba(255,255,0,.28);opacity:0}
.ext-lit--1{animation:ext-lit1 12s linear infinite}
.ext-lit--2{animation:ext-lit2 12s linear infinite}
.ext-lit--3{animation:ext-lit3 12s linear infinite}
.ext-coin{offset-path:path('M362 250c80-30 118-30 188-12');offset-rotate:0deg;animation:ext-pay 12s linear infinite}
.ext-ring{stroke:var(--yellow);opacity:0;transform-box:fill-box;transform-origin:center;animation:lox-ping 12s linear infinite}
.ext-ring--1{animation-delay:3.2s}
.ext-ring--2{animation-delay:7.2s}
.ext-ring--3{animation-delay:11.1s}
@keyframes ext-lock{0%,26%{transform:rotate(0)}30%,59%{transform:rotate(120deg)}63%,92%{transform:rotate(240deg)}96%,100%{transform:rotate(360deg)}}
@keyframes ext-lit1{0%,2%{opacity:0}6%,100%{opacity:1}}
@keyframes ext-lit2{0%,35%{opacity:0}39%,100%{opacity:1}}
@keyframes ext-lit3{0%,68%{opacity:0}72%,100%{opacity:1}}
@keyframes ext-pay{0%,8%{offset-distance:0%;opacity:0}10%{opacity:1}26%{offset-distance:100%;opacity:1}27%{offset-distance:100%;opacity:0}32%,41%{offset-distance:0%;opacity:0}43%{opacity:1}59%{offset-distance:100%;opacity:1}60%{offset-distance:100%;opacity:0}65%,74%{offset-distance:0%;opacity:0}76%{opacity:1}92%{offset-distance:100%;opacity:1}93%{offset-distance:100%;opacity:0}98%,100%{offset-distance:0%;opacity:0}}

/* běží až po odhalení sekce (data-reveal → is-in) */
.svganim :is(.sok-route,.sok-chip,.sok-ring,.sok-guard,.sok-guard-halo,.tech-cam,.tech-alert,.tech-ping,.tech-ok,.tech-signal,.tech-beacon,.tech-car,.tech-car-halo,.rad-sweep,.rad-blip,.lox-hub-ring,.lox-link,.lox-dev,.lox-ring,.cln-glass,.cln-shine,.cln-squeegee,.cln-spark,.rea-house,.rea-light,.rea-pin,.rea-tag,.ext-path,.ext-lit,.ext-coin,.ext-dial,.ext-ring){animation-play-state:paused}
.svganim.is-in :is(.sok-route,.sok-chip,.sok-ring,.sok-guard,.sok-guard-halo,.tech-cam,.tech-alert,.tech-ping,.tech-ok,.tech-signal,.tech-beacon,.tech-car,.tech-car-halo,.rad-sweep,.rad-blip,.lox-hub-ring,.lox-link,.lox-dev,.lox-ring,.cln-glass,.cln-shine,.cln-squeegee,.cln-spark,.rea-house,.rea-light,.rea-pin,.rea-tag,.ext-path,.ext-lit,.ext-coin,.ext-dial,.ext-ring){animation-play-state:running}
/* fallback: bez podpory offset-path pohyblivé prvky skryjeme (scéna zůstane statická) */
@supports not (offset-path: path('M0 0h1')){.sok-guard,.tech-car,.ext-coin{display:none}}

/* ============================================================
   DIVISION HERO (sub-page header)
   ============================================================ */
.page-hero{position:relative;padding-top:calc(var(--header-h) + clamp(40px,7vw,90px));padding-bottom:clamp(40px,7vw,90px);overflow:hidden}
.page-hero__media{position:absolute;inset:0;z-index:0}
.page-hero__media img{width:100%;height:100%;object-fit:cover;filter:grayscale(.3) brightness(.4)}
.page-hero__media::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,#000 30%,rgba(0,0,0,.55))}
.page-hero__inner{position:relative;z-index:1;max-width:680px}
.page-hero .eyebrow{color:var(--yellow)}
.page-hero h1{font-size:clamp(2.2rem,5.5vw,4rem);text-transform:uppercase;color:#fff;margin-bottom:.4em;letter-spacing:-.02em}
.page-hero__lead{font-size:clamp(1.05rem,1.8vw,1.25rem);color:var(--text);max-width:52ch}
.page-hero__badge{position:absolute;right:var(--gutter);bottom:30px;z-index:1;height:clamp(70px,12vw,120px);width:auto;opacity:.95}
.breadcrumb{font-size:.85rem;color:var(--muted);margin-bottom:18px;display:flex;gap:8px;flex-wrap:wrap}
.breadcrumb a:hover{color:var(--yellow)}
.breadcrumb span{color:var(--gray)}

/* ============================================================
   CTA BAND (yellow)
   ============================================================ */
.cta-band{background:var(--yellow);color:#000;text-align:center}
.cta-band .section{padding-block:clamp(48px,6vw,80px)}
.cta-band h2{color:#000;font-size:clamp(1.6rem,4vw,2.8rem);text-transform:uppercase;margin-bottom:.5em;letter-spacing:-.01em}
.cta-band p{color:#1a1a1a;font-size:1.1rem;max-width:50ch;margin:0 auto 28px;font-weight:500}
.cta-band__actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}

/* small contact strip (alt) */
.contact-strip{display:flex;align-items:center;justify-content:center;gap:clamp(20px,5vw,60px);flex-wrap:wrap;text-align:center}
.contact-strip a{font-family:var(--font-display);font-weight:800;font-size:clamp(1.1rem,2.5vw,1.6rem);color:#fff}
.contact-strip a:hover{color:var(--yellow)}

/* ============================================================
   PROPERTY CARDS (High Reality)
   ============================================================ */
.props{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:24px}
.prop{position:relative;background:var(--card);border:1px solid var(--line);border-radius:6px;overflow:hidden;transition:.3s var(--ease)}
.prop:hover{border-color:rgba(255,255,0,.4);transform:translateY(-3px)}
.prop__media{position:relative;aspect-ratio:4/3;overflow:hidden}
.prop__media img{width:100%;height:100%;object-fit:cover;transition:.5s var(--ease)}
.prop:hover .prop__media img{transform:scale(1.06)}
.prop__tag{position:absolute;top:12px;left:12px;background:var(--yellow);color:#000;font-family:var(--font-display);font-weight:800;font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;padding:5px 12px;border-radius:3px}
.prop__body{padding:20px}
.prop__title{font-family:var(--font-display);font-weight:700;color:#fff;font-size:1.1rem;margin-bottom:4px}
.prop__loc{color:var(--muted);font-size:.9rem;margin-bottom:14px}
.prop__meta{display:flex;gap:14px;color:var(--text);font-size:.85rem;border-top:1px solid var(--line);padding-top:14px;margin-bottom:14px}
.prop__price{font-family:var(--font-display);font-weight:900;color:var(--yellow);font-size:1.35rem}
.props-note{margin-top:28px;text-align:center;color:var(--muted);font-size:.9rem}

/* ============================================================
   FORM (kontakt)
   ============================================================ */
.form{display:grid;gap:18px}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{display:flex;flex-direction:column;gap:8px;min-width:0}
.field label{font-family:var(--font-display);font-weight:700;font-size:.82rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text)}
.field input,.field select,.field textarea{
  width:100%;min-width:0;max-width:100%;box-sizing:border-box;
  background:#0c0c0c;border:1px solid var(--line-strong);border-radius:var(--radius);color:#fff;
  padding:14px 16px;font-family:var(--font-body);font-size:1rem;transition:.2s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--yellow);box-shadow:0 0 0 3px rgba(255,255,0,.12)}
.field textarea{min-height:140px;resize:vertical}
.field--check{flex-direction:row;align-items:flex-start;gap:12px}
.field--check input{width:20px;height:20px;accent-color:var(--yellow);flex:none;margin-top:3px}
.field--check label{font-family:var(--font-body);text-transform:none;letter-spacing:0;font-weight:400;font-size:.9rem;color:var(--muted)}

/* info column (kontakt) */
.info-list{display:grid;gap:24px}
.info-list dt{font-family:var(--font-display);font-weight:800;text-transform:uppercase;letter-spacing:.06em;font-size:.78rem;color:var(--yellow);margin-bottom:4px}
.info-list dd{margin:0;font-size:1.2rem;font-family:var(--font-display);font-weight:700;color:#fff}
.info-list dd a:hover{color:var(--yellow)}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:#060606;border-top:1px solid var(--line);padding-top:clamp(48px,6vw,80px)}
.site-footer__grid{
  display:grid;grid-template-columns:1.6fr 1fr 1fr 1.7fr;gap:clamp(28px,4vw,56px);
  padding-bottom:clamp(40px,5vw,64px);
}
.site-footer__brand img{height:auto;width:140px;margin-bottom:18px}
.site-footer__tagline{color:var(--muted);font-size:.9rem;letter-spacing:.02em;margin:0}
.site-footer__col h3{
  font-family:var(--font-display);font-size:.8rem;text-transform:uppercase;letter-spacing:.16em;
  color:var(--yellow);margin-bottom:18px;font-weight:800;
}
.site-footer__col ul{display:grid;gap:11px}
.site-footer__col ul a{color:var(--text);font-size:.96rem;transition:.2s}
.site-footer__col ul a:hover{color:var(--yellow)}
.site-footer__contact li{color:var(--text);font-size:.96rem;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.site-footer__note{margin:18px 0 0;color:var(--muted);font-size:.82rem;line-height:1.6}
.badge{display:inline-block;background:var(--yellow);color:#000;font-family:var(--font-display);font-weight:800;font-size:.62rem;letter-spacing:.08em;padding:2px 8px;border-radius:3px}
.site-footer__bottom{border-top:1px solid var(--line);padding-block:22px}
.site-footer__bottom-inner{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.site-footer__bottom p{margin:0;color:var(--muted);font-size:.85rem}
.site-footer__legal a:hover{color:var(--yellow)}
@media (max-width:860px){
  .site-footer__grid{grid-template-columns:1fr 1fr;gap:32px}
  .site-footer__brand{grid-column:1 / -1}
}
@media (max-width:520px){
  .site-footer__grid{grid-template-columns:1fr}
  .site-footer__bottom-inner{flex-direction:column;align-items:flex-start}
}

/* ============================================================
   GRID HELPERS
   ============================================================ */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,64px);align-items:start}
/* povinná pole formulářů */
.field .req{color:var(--yellow);margin-left:2px;font-weight:700}
.form__note{color:var(--muted);font-size:.8rem;margin:-6px 0 14px}

/* hlášky formulářů (odesláno / chyba) */
.form-msg{padding:14px 18px;border-radius:6px;margin-bottom:20px;font-size:.95rem;line-height:1.55}
.form-msg--ok{background:rgba(40,160,70,.12);border:1px solid #2c7a3f;color:#b9f0c5}
.form-msg--err{background:rgba(200,60,40,.12);border:1px solid #a03327;color:#ffc9c0}
.form-msg a{color:var(--yellow)}

.prose p{margin-bottom:1.1em}
.prose p:last-child{margin-bottom:0}
.prose ul{list-style:disc;margin:0 0 1.1em 22px}
.prose ul li{margin-bottom:.35em}
.prose ul li::marker{color:var(--yellow)}
.prose a{color:var(--yellow)}
/* právní stránky: menší mezititulky */
.page-gdpr .prose .sect-title{font-size:clamp(1.25rem,2.4vw,1.7rem);margin-top:40px;padding-bottom:.4em}
.page-gdpr .prose .sect-title::after{width:56px;height:3px}

/* reveal on scroll */
[data-reveal]{opacity:0;transform:translateY(24px);transition:.7s var(--ease)}
[data-reveal].is-in{opacity:1;transform:none}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .nav-menu__item--cta{display:none}
}
@media (max-width:900px){
  :root{--header-h:70px}
  .nav-toggle{display:flex;order:3;position:relative;z-index:130}
  body.nav-open .nav-toggle span:not(.visually-hidden){background:#fff}
  .main-nav{margin-left:auto}
  .nav-menu{
    position:fixed;top:0;right:0;height:100dvh;width:min(360px,88vw);z-index:120;
    flex-direction:column;align-items:stretch;gap:0;padding:84px 24px 26px;
    background:#0a0a0a;border-left:2px solid var(--yellow);
    box-shadow:-30px 0 60px rgba(0,0,0,.6);
    transform:translateX(100%);transition:transform .35s var(--ease);
    overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;
  }
  body.nav-open .nav-menu{transform:translateX(0)}
  body.nav-open{overflow:hidden}
  body.nav-open .site-header{background:#000;border-bottom-color:var(--line)}
  /* crisp, high-contrast links + dividers for structure */
  .nav-menu__item{border-bottom:1px solid var(--line)}
  .nav-menu__item>a:not(.btn){color:#fff;padding:14px 6px;font-size:1.12rem;font-weight:800;letter-spacing:.02em}
  .nav-menu__item>a:not(.btn):hover,.nav-menu__item>a:not(.btn).is-active{color:var(--yellow)}
  .nav-menu__item--cta{display:block;border-bottom:0;margin:24px 0 0}
  .nav-menu__item--cta .btn{width:100%;padding:16px}
  .dropdown{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;background:transparent;padding:0 0 10px 4px;min-width:0}
  .dropdown li a{padding:9px 8px;border-radius:6px}
  .dropdown li a strong{font-size:1rem;color:#fff}
  .dropdown li a span{display:none}
  .dropdown li a:hover{background:#161616}
  body.nav-open .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  body.nav-open .nav-toggle span:nth-child(2){opacity:0}
  body.nav-open .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .site-header__phone{display:none}
  .nav-overlay{position:fixed;inset:0;background:rgba(0,0,0,.72);z-index:90;opacity:0;visibility:hidden;transition:.3s}
  body.nav-open .nav-overlay{opacity:1;visibility:visible}
}
@media (max-width:760px){
  .stats{grid-template-columns:1fr 1fr;gap:30px}
  .split{grid-template-columns:1fr}
  .split--rev .split__media{order:0}
  .split__media{min-height:260px}
  .grid-2{grid-template-columns:1fr}
  .bullets--cols{grid-template-columns:1fr}
  .svc{grid-template-columns:1fr;gap:18px}
  .form__row{grid-template-columns:1fr}
  .page-hero__media::after{background:linear-gradient(180deg,rgba(0,0,0,.6),rgba(0,0,0,.85))}
  .page-hero__badge{opacity:.5}
}
@media (max-width:420px){
  body{font-size:16px}
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important;scroll-behavior:auto}
  [data-reveal]{opacity:1;transform:none}
}

/* ============================================================
   IKONY + OBOHACUJÍCÍ PRVKY (v2)
   ============================================================ */
.ic{width:1.25em;height:1.25em;flex:none;display:inline-block;vertical-align:-.18em}

/* o něco hutnější rytmus sekcí */
.section{padding-block:clamp(56px,7vw,96px)}
.section--tight{padding-block:clamp(40px,5vw,64px)}

/* --- ikona v kartě (Proč HIGH GROUP) --- */
.card__icon{width:54px;height:54px;border:2px solid var(--yellow);border-radius:14px;color:var(--yellow);display:grid;place-items:center;margin-bottom:18px;transition:.3s var(--ease)}
.card__icon .ic{width:26px;height:26px}
.card:hover .card__icon{background:var(--yellow);color:#000}

/* divizní ikona v dlaždici (vedle lockupu) */
.tile__media .tile-ic{position:absolute;top:14px;left:14px;z-index:1;width:40px;height:40px;border-radius:10px;background:rgba(0,0,0,.5);border:1px solid rgba(255,255,0,.4);color:var(--yellow);display:grid;place-items:center;backdrop-filter:blur(4px)}
.tile__media .tile-ic .ic{width:20px;height:20px}
/* ikona v dropdownu */
.dropdown li a{display:flex;flex-direction:column;gap:5px}
.dropdown .dd-head{display:flex;align-items:center;gap:10px}
.dropdown .dd-ic{flex:none;width:24px;height:24px;color:var(--yellow);display:grid;place-items:center}
.dropdown .dd-ic .ic{width:22px;height:22px}
.dropdown .dd-desc{color:var(--muted);font-size:.82rem;padding-left:34px}

/* --- TRUST / loga klientů --- */
.logos{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:clamp(14px,2.4vw,26px)}
.logos__item{font-family:var(--font-display);font-weight:800;font-size:clamp(1.4rem,2.4vw,2.1rem);letter-spacing:.12em;text-transform:uppercase;
  color:#cfcfcf;opacity:1;white-space:nowrap;
  padding:14px 30px;border:1px solid var(--line);border-radius:50px;background:rgba(255,255,255,.025);
  transition:.3s var(--ease)}
.logos__item:hover{color:#000;background:var(--yellow);border-color:var(--yellow);transform:translateY(-2px)}

/* Výraznější mřížka log (homepage) — orámované buňky */
.logos--framed{display:grid;grid-template-columns:repeat(6,1fr);gap:16px}
.logos--framed .logos__item{display:flex;align-items:center;justify-content:center;min-height:96px;padding:18px 14px;border-radius:10px;
  background:var(--card);border:1px solid var(--line);font-size:clamp(1.25rem,1.8vw,1.7rem)}
.logos--framed .logos__item:hover{transform:translateY(-3px);border-color:var(--yellow);background:#161616;color:var(--yellow);
  box-shadow:0 16px 36px rgba(0,0,0,.45)}
@media (max-width:900px){.logos--framed{grid-template-columns:repeat(3,1fr)}}
@media (max-width:520px){.logos--framed{grid-template-columns:repeat(2,1fr)}}
.logos-eyebrow{text-align:center;margin-bottom:30px}

/* --- PROCES / Jak to probíhá --- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(20px,2.4vw,34px);position:relative}
.step{position:relative;text-align:center}
.step__ic{width:74px;height:74px;border:2px solid var(--line-strong);border-radius:50%;display:grid;place-items:center;color:var(--yellow);margin:0 auto 20px;background:var(--panel-2);position:relative;z-index:1;transition:.3s var(--ease)}
.step__ic .ic{width:30px;height:30px}
.step:hover .step__ic{border-color:var(--yellow);transform:translateY(-4px)}
.step__n{position:absolute;top:-4px;right:calc(50% - 46px);width:26px;height:26px;border-radius:50%;background:var(--yellow);color:#000;font-family:var(--font-display);font-weight:800;font-size:.82rem;display:grid;place-items:center;z-index:2}
.step h3{font-size:1.12rem;text-transform:uppercase;margin-bottom:8px;letter-spacing:.01em}
.step p{color:var(--text);font-size:.95rem;margin:0}
/* spojnice mezi kroky */
.steps::before{content:"";position:absolute;top:37px;left:12.5%;right:12.5%;height:2px;background:repeating-linear-gradient(90deg,var(--line-strong) 0 10px,transparent 10px 18px);z-index:0}

/* --- BADGES / certifikace --- */
.badges{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}
.badge-chip{display:inline-flex;align-items:center;gap:11px;border:1px solid var(--line-strong);border-radius:999px;padding:13px 22px;background:#0c0c0c;color:#fff;font-family:var(--font-display);font-weight:700;font-size:.92rem;transition:.3s var(--ease)}
.badge-chip:hover{border-color:rgba(255,255,0,.55);transform:translateY(-2px)}
.badge-chip .ic{color:var(--yellow);width:22px;height:22px}

/* --- REFERENCE / recenze --- */
.stars{display:flex;gap:3px;margin-bottom:14px}
.stars .ic{width:18px;height:18px;color:var(--yellow);fill:var(--yellow)}
.quote-card p{color:var(--text-strong);font-size:1.05rem;line-height:1.55;margin:0 0 16px}
.quote-card cite{font-style:normal;color:var(--muted);font-size:.9rem}

/* --- NONSTOP pruh --- */
.nonstop{position:relative;border-block:1px solid var(--line);background:
  radial-gradient(80% 120% at 100% 0%,rgba(255,255,0,.06),transparent 60%),#0a0a0a}
.nonstop__inner{display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;padding-block:clamp(32px,4vw,48px)}
.nonstop__l{display:flex;align-items:center;gap:22px}
.nonstop__ic{width:64px;height:64px;border-radius:50%;background:var(--yellow);color:#000;display:grid;place-items:center;flex:none}
.nonstop__ic .ic{width:30px;height:30px}
.nonstop__label{font-family:var(--font-display);font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--yellow);font-size:.78rem}
.nonstop__num{font-family:var(--font-display);font-weight:900;font-size:clamp(1.6rem,3.5vw,2.4rem);color:#fff;line-height:1}
.nonstop__num a:hover{color:var(--yellow)}

/* --- REGION / působnost --- */
.region__grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(30px,5vw,64px);align-items:center}
.region__panel{position:relative;border:1px solid var(--line);border-radius:12px;background:var(--panel-2);padding:clamp(30px,4vw,46px);text-align:center;overflow:hidden}
.region__panel::before{content:"";position:absolute;inset:0;background-image:url('/assets/img/brand/pattern-tile.png');background-size:150px;opacity:.3}
.region__pin{position:relative;width:84px;height:84px;border-radius:50%;background:var(--yellow);color:#000;display:grid;place-items:center;margin:0 auto 18px}
.region__pin .ic{width:40px;height:40px}
.region__city{position:relative;font-family:var(--font-display);font-weight:900;font-size:2rem;color:#fff;text-transform:uppercase;letter-spacing:.02em}
.region__note{position:relative;color:var(--muted);margin:6px 0 0}
.region__list{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.region__list span{border:1px solid var(--line);border-radius:6px;padding:8px 14px;color:var(--text);font-size:.9rem}

/* --- FAQ --- */
.faq{max-width:860px;margin-inline:auto}
.faq__item{border-bottom:1px solid var(--line)}
.faq__item summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:22px 4px;font-family:var(--font-display);font-weight:700;font-size:clamp(1.02rem,1.5vw,1.18rem);color:#fff;transition:.2s}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary:hover{color:var(--yellow)}
.faq__q-ic{flex:none;width:34px;height:34px;border:1px solid var(--line-strong);border-radius:8px;display:grid;place-items:center;color:var(--yellow);transition:.3s var(--ease)}
.faq__q-ic .ic{width:18px;height:18px}
.faq__item[open] .faq__q-ic{background:var(--yellow);color:#000;transform:rotate(135deg)}
.faq__item .faq__a{padding:0 4px 22px;color:var(--text);max-width:72ch}

/* --- plovoucí telefon (mobil) --- */
.float-call{position:fixed;right:16px;bottom:16px;z-index:85;width:58px;height:58px;border-radius:50%;background:var(--yellow);color:#000;display:none;place-items:center;box-shadow:0 10px 30px rgba(0,0,0,.5);animation:callpulse 2.4s var(--ease) infinite}
.float-call .ic{width:26px;height:26px}
@keyframes callpulse{0%,100%{box-shadow:0 10px 30px rgba(0,0,0,.5),0 0 0 0 rgba(255,255,0,.5)}50%{box-shadow:0 10px 30px rgba(0,0,0,.5),0 0 0 12px rgba(255,255,0,0)}}

/* --- responsive pro nové prvky --- */
@media (max-width:860px){
  .float-call{display:grid}
  .steps{grid-template-columns:1fr 1fr;gap:30px}
  .steps::before{display:none}
  .region__grid{grid-template-columns:1fr}
  .nonstop__inner{flex-direction:column;text-align:center}
  .nonstop__l{flex-direction:column;gap:14px}
}
@media (max-width:520px){
  .steps{grid-template-columns:1fr}
}

/* --- kontaktní osoby --- */
.person__role{color:var(--yellow);font-family:var(--font-display);font-weight:700;font-size:.85rem;text-transform:uppercase;letter-spacing:.06em;margin:0 0 14px}
.person__line{display:flex;align-items:center;gap:10px;margin:0 0 8px;color:var(--text);font-size:.95rem}
.person__line .ic{color:var(--yellow);width:18px;height:18px;flex:none}
.person__line a:hover{color:var(--yellow)}

/* --- mapy --- */
.maps-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,2.4vw,28px)}
.map-card{margin:0}
.map-embed{position:relative;aspect-ratio:16/10;border:1px solid var(--line-strong);border-radius:10px;overflow:hidden;background:#0c0c0c}
.map-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0;filter:invert(.92) hue-rotate(180deg) brightness(.95) contrast(.9) grayscale(.25)}
.map-card figcaption{display:flex;align-items:flex-start;gap:12px;margin-top:16px}
.map-card__ic{flex:none;width:38px;height:38px;border-radius:10px;background:var(--yellow);color:#000;display:grid;place-items:center}
.map-card__ic .ic{width:20px;height:20px}
.map-card figcaption span:last-child{display:flex;flex-direction:column;gap:2px;color:var(--text)}
.map-card figcaption strong{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.04em;color:#fff;font-size:.9rem}
@media (max-width:760px){.maps-grid{grid-template-columns:1fr}}

/* --- loga klientů: monochromatický režim pro obrázková loga --- */
.logos__item--img{display:inline-flex;align-items:center}
.logos__item--img img{height:36px;width:auto;filter:grayscale(1) brightness(0) invert(.7);opacity:.85;transition:.3s var(--ease)}
.logos__item--img:hover img{filter:grayscale(1) brightness(0) invert(1);opacity:1}

/* ============================================================
   VÝPIS NEMOVITOSTÍ (listings) + stránkování
   ============================================================ */
.page-hero--compact{padding-top:calc(var(--header-h) + clamp(30px,5vw,56px));padding-bottom:clamp(30px,5vw,56px)}

.section--listings{padding-top:clamp(28px,4vw,44px)}
.listing-filter{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:16px;align-items:end;
  background:var(--panel-2);border:1px solid var(--line);border-radius:10px;padding:clamp(18px,2.4vw,26px);margin-bottom:28px}
.listing-filter .field--btn .btn{width:100%}
.listing-filter .btn .ic{width:18px;height:18px}
.listing-count{color:var(--muted);font-size:.95rem;margin:0 0 24px}
.listing-count strong{color:#fff}

.pagination{display:flex;justify-content:center;align-items:center;gap:8px;margin-top:clamp(36px,5vw,56px)}
.pagination__num,.pagination__btn{display:grid;place-items:center;min-width:46px;height:46px;padding:0 6px;
  border:1px solid var(--line-strong);border-radius:8px;color:var(--text);font-family:var(--font-display);font-weight:800;transition:.2s var(--ease)}
.pagination__num:hover,.pagination__btn:hover{border-color:var(--yellow);color:var(--yellow)}
.pagination__num.is-active{background:var(--yellow);border-color:var(--yellow);color:#000}
.pagination__btn .ic{width:20px;height:20px}
.pagination__prev{transform:rotate(180deg)}
.pagination__btn.is-disabled{opacity:.35;pointer-events:none}
@media (max-width:680px){
  .listing-filter{grid-template-columns:1fr 1fr}
  .listing-filter .field--btn{grid-column:1 / -1}
}
@media (max-width:520px){
  .listing-filter{grid-template-columns:1fr}
}

/* ============================================================
   Vodorovně scrollovatelné karty (reference)
   ============================================================ */
.cards--scroll{display:flex;flex-wrap:nowrap;overflow-x:auto;gap:20px;
  scroll-snap-type:x mandatory;padding-bottom:16px;scroll-padding-left:var(--gutter);
  cursor:grab;scrollbar-width:none}
.cards--scroll::-webkit-scrollbar{height:0}
.cards--scroll.is-dragging{cursor:grabbing;scroll-snap-type:none;scroll-behavior:auto;user-select:none}
.cards--scroll>*{flex:0 0 clamp(280px,32%,360px);scroll-snap-align:start}
@media (max-width:760px){.cards--scroll>*{flex:0 0 82%}}

/* navigace scrolleru (šipky + náznak přetečení) */
.cards-scroller{position:relative}
.cards-scroller.has-overflow::after{content:"";position:absolute;top:0;right:0;bottom:16px;width:64px;
  pointer-events:none;background:linear-gradient(90deg,transparent,var(--panel))}
.cards-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:52px;height:52px;border:0;border-radius:50%;
  background:var(--yellow);color:#000;display:grid;place-items:center;cursor:pointer;
  box-shadow:0 10px 26px rgba(0,0,0,.45);transition:.2s var(--ease)}
.cards-nav:hover{transform:translateY(-50%) scale(1.08)}
.cards-nav .ic{width:26px;height:26px}
.cards-nav--prev{left:6px}
.cards-nav--prev .ic{transform:rotate(180deg)}
.cards-nav--next{right:6px}
.cards-nav.is-hidden{opacity:0;visibility:hidden;pointer-events:none}
@media (max-width:640px){.cards-nav{width:44px;height:44px}.cards-nav .ic{width:22px;height:22px}}

/* CTA tlačítka v hero podstránky */
.page-hero__actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}
@media (max-width:520px){.page-hero__actions .btn{width:100%}}

/* ============================================================
   DETAIL NEMOVITOSTI (estate)
   ============================================================ */
.estate{padding-block:0 clamp(48px,7vw,90px)}
.estate__head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin:6px 0 22px}
.estate__title{font-size:clamp(1.6rem,3.4vw,2.6rem);text-transform:none;letter-spacing:-.01em}
.estate__loc{display:flex;align-items:center;gap:8px;color:var(--text);margin:10px 0 0}
.estate__loc .ic{color:var(--yellow);width:20px;height:20px}
.estate__price{text-align:right}
.estate__status{display:inline-block;background:var(--yellow);color:#000;font-family:var(--font-display);font-weight:800;font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;padding:4px 10px;border-radius:3px;margin-bottom:8px}
.estate__price-val{display:block;font-family:var(--font-display);font-weight:900;font-size:clamp(1.6rem,3vw,2.4rem);color:var(--yellow);line-height:1}

/* galerie */
.estate__gallery{display:grid;gap:14px;margin-bottom:30px}
.estate__main{position:relative;border-radius:12px;overflow:hidden;border:1px solid var(--line);aspect-ratio:16/10;background:#0c0c0c}
.estate__main img{width:100%;height:100%;object-fit:cover}
.estate__main .prop__tag{top:16px;left:16px}
.estate__thumbs{display:grid;grid-template-columns:repeat(8,1fr);gap:10px}
.estate__thumb{padding:0;border:2px solid transparent;border-radius:8px;overflow:hidden;cursor:pointer;background:none;aspect-ratio:4/3}
.estate__thumb img{width:100%;height:100%;object-fit:cover;display:block}
.estate__thumb.is-active{border-color:var(--yellow)}

/* klíčové parametry */
.estate__keys{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-bottom:34px}
.estate__key{background:var(--panel-2);border:1px solid var(--line);border-radius:10px;padding:16px;text-align:center}
.estate__key .ic{width:26px;height:26px;color:var(--yellow);margin:0 auto 8px}
.estate__key span{display:block;font-family:var(--font-display);font-weight:800;color:#fff;font-size:1.05rem}
.estate__key small{display:block;color:var(--muted);font-size:.78rem;margin-top:2px}

/* layout obsah + sidebar */
.estate__grid{display:grid;grid-template-columns:1fr 360px;gap:clamp(28px,4vw,48px);align-items:start}
.estate__desc{color:var(--text)}
.estate__params{width:100%;border-collapse:collapse;margin-top:8px}
.estate__params th,.estate__params td{padding:11px 14px;border-bottom:1px solid var(--line);text-align:left;font-size:.96rem}
.estate__params th{color:var(--muted);font-weight:600;width:42%;font-family:var(--font-body);text-transform:none;letter-spacing:0;background:none}
.estate__params td{color:#fff}
/* parametry v logických celcích — dva sloupce přesně 50/50, na mobilu 100 % */
.estate__params-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));column-gap:28px;align-items:start;margin-top:4px}
.estate__pcol{min-width:0}
.estate__pgroup{margin-bottom:22px}
.estate__pgroup-title{font-family:var(--font-display);font-weight:800;font-size:.76rem;text-transform:uppercase;letter-spacing:.1em;color:var(--yellow);margin:0 0 2px}
/* řádky jako flex: label vlevo v JEDNOTNÉ šířce, hodnota vpravo; dlouhá hodnota se nezalamuje
   uprostřed — když se vedle labelu nevejde, sklouzne celá na vlastní řádek (zarovnaná vpravo) */
.estate__pgroup .estate__params{display:block;margin-top:0}
.estate__pgroup .estate__params tbody{display:block}
.estate__pgroup .estate__params tr{display:flex;flex-wrap:wrap;align-items:baseline;column-gap:16px;border-bottom:1px solid var(--line)}
.estate__pgroup .estate__params th,.estate__pgroup .estate__params td{padding:7px 0;font-size:.88rem;border-bottom:0}
.estate__pgroup .estate__params th{width:auto;flex:0 0 11em;white-space:normal}
.estate__pgroup .estate__params td{flex:1 0 auto;max-width:100%;margin-left:auto;text-align:right}
@media (max-width:700px){.estate__params-grid{grid-template-columns:1fr}}
.estate__video{position:relative;aspect-ratio:16/9;border-radius:10px;overflow:hidden;border:1px solid var(--line)}
.estate__video iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.estate__map{margin-top:8px}

/* sidebar */
.estate__sticky{position:sticky;top:90px;display:flex;flex-direction:column;gap:18px}
.estate__price-card{background:var(--yellow);color:#000;border-radius:12px;padding:20px 22px}
.estate__price-card-label{display:block;font-family:var(--font-display);font-weight:800;text-transform:uppercase;letter-spacing:.08em;font-size:.74rem}
.estate__price-card-val{display:block;font-family:var(--font-display);font-weight:900;font-size:1.7rem;line-height:1.1;margin-top:4px}
.agent{display:flex;gap:14px;align-items:center;background:var(--panel-2);border:1px solid var(--line);border-radius:12px;padding:16px}
.agent__photo{width:64px;height:64px;border-radius:50%;object-fit:cover;flex:none;border:2px solid var(--yellow)}
.agent__photo--ph{display:grid;place-items:center;background:#161616;color:var(--yellow)}
.agent__photo--ph .ic{width:28px;height:28px}
.agent__info strong{display:block;font-family:var(--font-display);color:#fff;font-size:1.05rem}
.agent__info span{color:var(--muted);font-size:.85rem}
.agent__actions{display:grid;gap:10px}
.agent__actions .btn{width:100%}
.estate__inquiry{background:var(--panel-2);border:1px solid var(--line);border-radius:12px;padding:20px;gap:12px}
.estate__inquiry-h{font-family:var(--font-display);font-weight:800;color:#fff;margin:0 0 4px}
.estate__inquiry .btn{width:100%}

@media (max-width:900px){
  .estate__grid{grid-template-columns:1fr}
  .estate__sticky{position:static}
  .estate__keys{grid-template-columns:repeat(3,1fr)}
  .estate__thumbs{grid-template-columns:repeat(5,1fr)}
}
@media (max-width:540px){
  .estate__keys{grid-template-columns:repeat(2,1fr)}
  .estate__thumbs{grid-template-columns:repeat(4,1fr)}
  .estate__head{flex-direction:column;align-items:flex-start}
  .estate__price{text-align:left}
}

/* ============================================================
   GALERIE detailu — tlačítkový main, lightbox, swipe
   ============================================================ */
.estate__main{display:block;width:100%;padding:0;border:1px solid var(--line);background:#0c0c0c;cursor:zoom-in;position:relative;border-radius:12px;overflow:hidden;aspect-ratio:16/10}
.estate__main img{width:100%;height:100%;object-fit:cover;display:block}
.estate__zoom{position:absolute;right:14px;bottom:14px;z-index:2;width:44px;height:44px;border-radius:50%;background:rgba(0,0,0,.55);color:#fff;display:grid;place-items:center;backdrop-filter:blur(4px);transition:.25s var(--ease)}
.estate__zoom .ic{width:22px;height:22px}
.estate__main:hover .estate__zoom{background:var(--yellow);color:#000}
.estate__count{position:absolute;left:16px;bottom:16px;z-index:2;background:rgba(0,0,0,.6);color:#fff;font-family:var(--font-display);font-weight:700;font-size:.78rem;padding:6px 12px;border-radius:20px;backdrop-filter:blur(4px)}

/* lightbox */
.lb{position:fixed;inset:0;z-index:300;background:rgba(0,0,0,.94);display:none;align-items:center;justify-content:center;touch-action:pan-y}
.lb.is-open{display:flex}
.lb__img{max-width:92vw;max-height:86vh;object-fit:contain;border-radius:4px;user-select:none;-webkit-user-drag:none}
.lb__btn{position:absolute;top:50%;transform:translateY(-50%);width:56px;height:56px;border:0;border-radius:50%;
  background:rgba(255,255,255,.08);color:#fff;display:grid;place-items:center;cursor:pointer;transition:.2s var(--ease)}
.lb__btn:hover{background:var(--yellow);color:#000}
.lb__btn .ic{width:30px;height:30px}
.lb__prev{left:18px}
.lb__prev .ic{transform:rotate(180deg)}
.lb__next{right:18px}
.lb__close{position:absolute;top:18px;right:18px;width:46px;height:46px;border:0;border-radius:50%;background:rgba(255,255,255,.08);color:#fff;font-size:24px;cursor:pointer;transition:.2s var(--ease);line-height:1}
.lb__close:hover{background:var(--yellow);color:#000}
.lb__counter{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);color:#fff;font-family:var(--font-display);font-weight:700;font-size:.85rem;background:rgba(0,0,0,.5);padding:6px 14px;border-radius:20px}
body.lb-open{overflow:hidden}
@media (max-width:640px){
  .lb__btn{width:44px;height:44px;background:rgba(255,255,255,.12)}
  .lb__btn .ic{width:24px;height:24px}
  .lb__prev{left:6px}.lb__next{right:6px}
}

/* AJAX listing — jemný fade při načítání */
#listingResults{transition:opacity .2s ease}
#listingResults.is-loading{opacity:.45;pointer-events:none}

/* ============================================================
   REFERENCE (prodané) + KONTAKT NA MAKLÉŘE (High Reality)
   ============================================================ */
.prop__tag--sold{background:var(--yellow);color:#000}
.prop--ref .prop__media img{filter:saturate(.85)}

.reality-cta{display:flex;flex-wrap:wrap;gap:16px;justify-content:center;margin:0 auto clamp(40px,6vw,64px)}

.agents{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}
.agent-card{display:flex;gap:16px;align-items:center;background:var(--card);border:1px solid var(--line);border-radius:8px;padding:18px;transition:.25s var(--ease)}
.agent-card:hover{border-color:var(--line-strong);transform:translateY(-2px)}
.agent-card__photo{width:74px;height:74px;border-radius:50%;object-fit:cover;flex:0 0 auto;background:#0c0c0c}
.agent-card__photo--ph{display:grid;place-items:center;color:var(--yellow)}
.agent-card__photo--ph .ic{width:34px;height:34px}
.agent-card__body{min-width:0}
.agent-card__name{display:block;font-family:var(--font-display);color:#fff;font-size:1.05rem;font-weight:800}
.agent-card__role{display:block;color:var(--muted);font-size:.82rem;margin-bottom:8px}
.agent-card__links{display:flex;flex-direction:column;gap:4px}
.agent-card__links a{display:inline-flex;align-items:center;gap:7px;color:var(--text);font-size:.9rem;word-break:break-word}
.agent-card__links a:hover{color:var(--yellow)}
.agent-card__links .ic{width:16px;height:16px;color:var(--yellow);flex:0 0 auto}

/* detail — poznámka u realizované zakázky (místo poptávkového formuláře) */
.estate__sold-note{background:var(--card);border:1px solid var(--line);border-radius:8px;padding:22px;display:flex;flex-direction:column;gap:12px}
.estate__sold-note .btn{width:100%}

/* „+N" náhled skrytých miniatur v galerii detailu */
.estate__thumbs.is-collapsed .estate__thumb.is-hidden{display:none}
.estate__thumb--more{position:relative}
.estate__more{position:absolute;inset:0;display:grid;place-items:center;background:rgba(0,0,0,.62);
  color:#fff;font-family:var(--font-display);font-weight:800;font-size:1.5rem;letter-spacing:.02em;
  cursor:pointer;transition:.2s var(--ease)}
.estate__thumb--more:hover .estate__more{background:rgba(0,0,0,.5);color:var(--yellow)}

/* Kontakt na makléře — 2 velké boxy po 50 % (High Reality) */
.agents--duo{grid-template-columns:repeat(2,1fr);max-width:920px;margin-inline:auto;gap:22px}
.agents--duo .agent-card{padding:26px;gap:22px}
.agents--duo .agent-card__photo{width:104px;height:104px}
.agents--duo .agent-card__name{font-size:1.25rem}
.agents--duo .agent-card__role{font-size:.9rem;margin-bottom:12px}
.agents--duo .agent-card__links a{font-size:.95rem}
@media (max-width:720px){.agents--duo{grid-template-columns:1fr}}

/* Kontaktní + mapový box pod makléři (High Reality) */
.reality-contact{display:grid;grid-template-columns:1fr 1fr;gap:22px;max-width:920px;margin:36px auto 0}
.reality-contact__box{background:var(--card);border:1px solid var(--line);border-radius:8px;overflow:hidden}
.reality-contact__box:not(.reality-contact__box--map){padding:26px}
.reality-contact__h{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-size:1.15rem;margin-bottom:16px;color:#fff}
.reality-contact__h .ic{width:22px;height:22px;color:var(--yellow)}
.reality-contact__list{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}
.reality-contact__list li{display:flex;align-items:flex-start;gap:11px;color:var(--text)}
.reality-contact__list .ic{width:18px;height:18px;color:var(--yellow);flex:0 0 auto;margin-top:3px}
.reality-contact__list a:hover{color:var(--yellow)}
.reality-contact__cta .btn{width:100%}
.reality-contact__box--map{min-height:280px}
.reality-contact__box--map .map-embed{height:100%;border:0;border-radius:0}
.reality-contact__box--map iframe{width:100%;height:100%;min-height:280px;border:0;display:block;filter:grayscale(.3) contrast(1.05)}
@media (max-width:720px){.reality-contact{grid-template-columns:1fr}}
