@charset "utf-8";

/* ═══════════════════════════════════════════════════════
   VYKUP-NEMOVITOSTI-S-NAJMEM.CSS
   Rozšiřuje style.css webu vykupyostrava.cz
   Prefix: vsn- (výkup s nájmem)
   ═══════════════════════════════════════════════════════ */


/* ─── MODEL FLOW — vizuální procesní osa (nová komponenta) ─── */
.vsn-model-flow{display:flex;flex-direction:column;gap:0;margin-top:2rem}
.vsn-model-flow__step{display:flex;align-items:flex-start;gap:1rem;padding:1.25rem 1.35rem;border-radius:var(--rl);background:var(--white);border:1px solid var(--line);box-shadow:var(--sh);transition:box-shadow var(--trans),border-color var(--trans),transform var(--trans)}
.vsn-model-flow__step:hover{box-shadow:var(--sh-lift);border-color:rgba(16,185,129,.18);transform:translateY(-2px)}
.vsn-model-flow__step--opt{border-style:dashed;border-color:rgba(16,185,129,.2);background:rgba(16,185,129,.015)}
.vsn-model-flow__num{width:38px;height:38px;flex:0 0 38px;border-radius:10px;display:grid;place-items:center;font-size:.82rem;font-weight:800;color:var(--accent);background:var(--accent-s);border:1px solid rgba(16,185,129,.12);transition:all var(--trans)}
.vsn-model-flow__step:hover .vsn-model-flow__num{background:var(--accent);color:#fff;border-color:var(--accent)}
.vsn-model-flow__step strong{display:block;font-size:15px;font-weight:700;color:var(--ink);margin-bottom:.2rem}
.vsn-model-flow__step>div>span{display:block;font-size:13.5px;line-height:1.55;color:var(--muted)}
.vsn-model-flow__tag{display:inline-block;padding:.1rem .55rem;border-radius:50px;font-size:.65rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;background:var(--accent-s);color:var(--accent);margin-left:.35rem;vertical-align:middle}
.vsn-model-flow__connector{display:flex;justify-content:center;padding:.4rem 0;color:var(--light);opacity:.4}

@media(max-width:575px){
  .vsn-model-flow__step{padding:1rem .95rem;gap:.75rem}
  .vsn-model-flow__num{width:32px;height:32px;flex:0 0 32px;font-size:.72rem}
  .vsn-model-flow__step strong{font-size:13.5px}
  .vsn-model-flow__step>div>span{font-size:12px}
}


/* ─── KEYBOX ─── */
.vsn-keybox{position:relative;display:flex;border-radius:var(--rl);background:var(--white);border:1px solid var(--line);box-shadow:var(--sh),0 8px 32px rgba(9,13,26,.06);overflow:hidden;margin-top:.5rem}
.vsn-keybox__accent{width:5px;flex-shrink:0;background:linear-gradient(180deg,var(--accent),var(--accent-glow))}
.vsn-keybox__body{padding:1.75rem 1.75rem;flex:1}
.vsn-keybox__body h3{font-size:17px;font-weight:700;color:var(--ink);margin:0 0 1.1rem;letter-spacing:-.02em}
.vsn-keybox__item{display:flex;align-items:center;gap:.75rem;padding:.6rem 0;font-size:14.5px;line-height:1.5;color:var(--muted);border-bottom:1px solid var(--line)}
.vsn-keybox__item:last-child{border-bottom:none}
.vsn-keybox__num{width:28px;height:28px;flex:0 0 28px;border-radius:8px;display:grid;place-items:center;font-size:.75rem;font-weight:800;color:var(--accent);background:var(--accent-s);border:1px solid rgba(16,185,129,.12);transition:all var(--trans)}
.vsn-keybox__item:hover .vsn-keybox__num{background:var(--accent);color:#fff;border-color:var(--accent)}

@media(max-width:575px){
  .vsn-keybox__body{padding:1.25rem 1.1rem}
  .vsn-keybox__body h3{font-size:15px}
  .vsn-keybox__item{font-size:13px;gap:.6rem}
  .vsn-keybox__num{width:24px;height:24px;flex:0 0 24px;font-size:.7rem}
}


/* ─── DUAL CARD — dvě karty vedle sebe (nová komponenta) ─── */
.vsn-dual{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
.vsn-dual__card{padding:2rem 1.75rem;border-radius:var(--rl);background:var(--white);border:1px solid var(--line);box-shadow:var(--sh),0 6px 24px rgba(9,13,26,.05);overflow:hidden}
.vsn-dual__card--green{border-top:3px solid var(--accent)}
.vsn-dual__card--amber{border-top:3px solid var(--amber)}
.vsn-dual__head{display:flex;align-items:center;gap:.75rem;margin-bottom:1.35rem}
.vsn-dual__ic{width:42px;height:42px;flex:0 0 42px;border-radius:11px;display:grid;place-items:center;transition:background var(--trans),color var(--trans)}
.vsn-dual__card--green .vsn-dual__ic{background:var(--accent-s);color:var(--accent)}
.vsn-dual__card--amber .vsn-dual__ic{background:var(--amber-s);color:var(--amber)}
.vsn-dual__head h3{font-size:18px;font-weight:700;color:var(--ink);margin:0;letter-spacing:-.02em}
.vsn-dual__list{display:flex;flex-direction:column;gap:0}
.vsn-dual__item{padding:.85rem 0;border-bottom:1px solid var(--line)}
.vsn-dual__item:last-child{border-bottom:none}
.vsn-dual__item strong{display:block;font-size:14.5px;font-weight:700;color:var(--ink);margin-bottom:.15rem}
.vsn-dual__item span{display:block;font-size:13.5px;line-height:1.55;color:var(--muted)}

@media(max-width:991px){.vsn-dual{grid-template-columns:1fr}}
@media(max-width:575px){
  .vsn-dual__card{padding:1.35rem 1.15rem}
  .vsn-dual__head h3{font-size:16px}
  .vsn-dual__ic{width:36px;height:36px;flex:0 0 36px}
  .vsn-dual__item strong{font-size:13.5px}
  .vsn-dual__item span{font-size:12px}
}


/* ─── TRUST STRIP (vertical, light) ─── */
.vsn-trust-strip{display:flex;flex-direction:column;gap:0;border-radius:var(--rl);overflow:hidden;background:var(--white);border:1px solid var(--line);box-shadow:var(--sh),0 6px 24px rgba(9,13,26,.05);margin-top:2rem}
.vsn-trust-strip__item{display:flex;align-items:flex-start;gap:.75rem;padding:1rem 1.15rem;border-bottom:1px solid var(--line);transition:background var(--trans)}
.vsn-trust-strip__item:last-child{border-bottom:none}
.vsn-trust-strip__item:hover{background:rgba(16,185,129,.02)}
.vsn-trust-strip__ic{width:36px;height:36px;flex:0 0 36px;border-radius:10px;display:grid;place-items:center;background:var(--accent-s);color:var(--accent);transition:background var(--trans),color var(--trans)}
.vsn-trust-strip__ic svg{display:block;width:18px;height:18px;margin:0}
.vsn-trust-strip__item:hover .vsn-trust-strip__ic{background:var(--accent);color:#fff}
.vsn-trust-strip__item strong{display:block;font-size:14px;font-weight:700;color:var(--ink);margin-bottom:.1rem}
.vsn-trust-strip__item>div>span{display:block;font-size:12.5px;line-height:1.4;color:var(--light)}

@media(max-width:575px){
  .vsn-trust-strip__item{padding:.85rem .9rem;gap:.6rem}
  .vsn-trust-strip__ic{width:32px;height:32px;flex:0 0 32px}
  .vsn-trust-strip__ic svg{width:16px;height:16px}
}


/* ─── TIMELINE ─── */
.vsn-timeline{position:relative;padding:1rem 0 0}
.vsn-timeline::before{content:'';position:absolute;left:20px;top:2.5rem;bottom:2.5rem;width:2px;background:#e3e8e3}
.vsn-timeline__step{position:relative;display:flex;align-items:flex-start;gap:1.25rem;padding:0 0 2rem}
.vsn-timeline__step:last-child{padding-bottom:0}
.vsn-timeline__num{position:relative;z-index:2;width:40px;height:40px;flex:0 0 40px;border-radius:10px;display:grid;place-items:center;font-size:.85rem;font-weight:800;letter-spacing:-.02em;color:#10b981;background:#fff;border:2px solid rgba(16,185,129,.2);transition:none}
.vsn-timeline__step:first-child .vsn-timeline__num{color:#7fb38a;border-color:#dbe6dc}
.vsn-timeline__step:hover .vsn-timeline__num{color:#fff;box-shadow:0 4px 16px rgba(16,185,129,.2);background:var(--accent);border-color:var(--accent)}
.vsn-timeline__body{flex:1;padding-top:.55rem}
.vsn-timeline__body h3{font-size:16px;font-weight:700;color:var(--ink);margin:0 0 .4rem;letter-spacing:-.02em}
.vsn-timeline__body p{font-size:14.5px;line-height:1.65;color:var(--muted);margin:0}
.vsn-timeline__badge{display:inline-block;margin-top:.6rem;padding:.25rem .7rem;border-radius:50px;font-size:.68rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;background:var(--accent-s);color:var(--accent)}
.vsn-timeline__note{display:flex;align-items:flex-start;gap:.65rem;margin-top:2rem;padding:1rem 1.25rem;border-radius:var(--r);background:var(--white);border:1px solid var(--line);box-shadow:var(--sh)}
.vsn-timeline__note svg{flex:0 0 16px;margin-top:.15rem;color:var(--light)}
.vsn-timeline__note p{font-size:13.5px;line-height:1.6;color:var(--light);margin:0}

@media(max-width:575px){
  .vsn-timeline::before{left:19px}
  .vsn-timeline__num{width:40px;height:40px;flex:0 0 40px;font-size:.75rem;border-radius:12px}
  .vsn-timeline__step{gap:1rem;padding-bottom:1.5rem}
  .vsn-timeline__body{padding-top:.35rem}
  .vsn-timeline__body h3{font-size:14.5px}
  .vsn-timeline__body p{font-size:13px}
  .vsn-timeline__badge{font-size:.62rem}
}


/* ─── LEGAL CHECKLIST GRID (nová komponenta) ─── */
.vsn-legal-grid{display:flex;flex-direction:column;gap:0;border-radius:var(--rl);overflow:hidden;background:var(--white);border:1px solid var(--line);box-shadow:var(--sh),0 6px 24px rgba(9,13,26,.05);margin-top:1.5rem}
.vsn-legal-item{display:flex;align-items:flex-start;gap:.75rem;padding:1rem 1.15rem;border-bottom:1px solid var(--line);transition:background var(--trans)}
.vsn-legal-item:last-child{border-bottom:none}
.vsn-legal-item:hover{background:rgba(16,185,129,.015)}
.vsn-legal-item__ic{width:34px;height:34px;flex:0 0 34px;border-radius:9px;display:flex;align-items:center;justify-content:center;background:var(--accent-s);color:var(--accent);margin-top:2px;transition:background var(--trans),color var(--trans)}
.vsn-legal-item__ic svg{display:block;width:16px;height:16px;margin:0}
.vsn-legal-item:hover .vsn-legal-item__ic{background:var(--accent);color:#fff}
.vsn-legal-item strong{display:block;font-size:14.5px;font-weight:700;color:var(--ink);margin-bottom:.15rem}
.vsn-legal-item>div>span{display:block;font-size:13.5px;line-height:1.5;color:var(--muted)}

@media(max-width:575px){
  .vsn-legal-item{padding:.85rem .9rem;gap:.6rem}
  .vsn-legal-item__ic{width:30px;height:30px;flex:0 0 30px}
  .vsn-legal-item__ic svg{width:14px;height:14px}
  .vsn-legal-item strong{font-size:13.5px}
  .vsn-legal-item>div>span{font-size:12px}
}


/* ─── INFO BOX (overlapping composition) ─── */
.vsn-pozor-comp{position:relative;padding-bottom:2rem}
.vsn-pozor-comp__img{border-radius:var(--rl);overflow:hidden;box-shadow:0 12px 40px rgba(9,13,26,.1)}
.vsn-pozor-comp__float{position:relative;margin-top:-8rem;margin-left:1.5rem;margin-right:.5rem;z-index:2}

.vsn-info-box{padding:1.75rem 1.5rem 1.5rem;border-radius:var(--rl);background:var(--ink);color:#fff;position:relative;overflow:hidden;box-shadow:0 8px 32px rgba(9,13,26,.18)}
.vsn-info-box::before{content:'';position:absolute;top:-40px;right:-40px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,rgba(16,185,129,.14) 0%,transparent 65%);pointer-events:none}
.vsn-info-box__head{display:flex;align-items:center;gap:.75rem;margin-bottom:.85rem;position:relative}
.vsn-info-box__ic{width:42px;height:42px;flex:0 0 42px;border-radius:11px;display:grid;place-items:center;background:var(--accent);color:#fff}
.vsn-info-box__head h3{font-size:17px;font-weight:700;color:#fff;margin:0;letter-spacing:-.02em}
.vsn-info-box p{font-size:14.5px;line-height:1.65;color:rgba(255,255,255,.82);margin:0 0 .55rem;position:relative}
.vsn-info-box p:last-child{margin-bottom:0}

@media(max-width:991px){.vsn-pozor-comp__float{margin-left:1rem;margin-right:0}}
@media(max-width:575px){
  .vsn-pozor-comp__float{margin-left:.5rem;margin-right:0;margin-top:-2rem}
  .vsn-info-box{padding:1.25rem 1.1rem}
  .vsn-info-box__ic{width:36px;height:36px;flex:0 0 36px}
  .vsn-info-box__head h3{font-size:15px}
  .vsn-info-box p{font-size:13px}
}


/* ─── COMPARE CARDS (3-way comparison in dark section) ─── */
.vsn-compare{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;align-items:stretch;margin-top:2rem}
.vsn-cmp{display:flex;flex-direction:column;padding:1.75rem 1.5rem 1.5rem;border-radius:var(--rx);background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);transition:box-shadow var(--trans),transform var(--trans)}
.vsn-cmp:hover{box-shadow:0 8px 32px rgba(0,0,0,.2);transform:translateY(-2px);border-color:rgba(255,255,255,.28)}
.vsn-cmp--hl{background:rgba(16,185,129,.08);border-color:rgba(52,211,153,.2)}
.vsn-cmp--hl:hover{border-color:rgba(52,211,153,.35);box-shadow:0 8px 40px rgba(16,185,129,.15)}
.vsn-cmp__head{margin-bottom:1rem}
.vsn-cmp__icon{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;background:rgba(255,255,255,.12);color:var(--accent-glow);margin-bottom:.85rem;transition:all var(--trans)}
.vsn-cmp:hover .vsn-cmp__icon{background:rgba(255,255,255,.16)}
.vsn-cmp--hl .vsn-cmp__icon{background:var(--accent);color:#fff}
.vsn-cmp__head h3{font-size:19px;font-weight:700;margin:0 0 .3rem;color:#fff}
.vsn-cmp__tag{display:block;font-size:13.5px;font-weight:500;color:rgba(255,255,255,.72)}
.vsn-cmp__rows{flex:1;display:flex;flex-direction:column;gap:0}
.vsn-cmp__row{display:flex;justify-content:space-between;gap:1rem;padding:.6rem 0;border-bottom:1px solid rgba(255,255,255,.08);font-size:14px;line-height:1.45;color:rgba(255,255,255,.88)}
.vsn-cmp__row:last-child{border-bottom:none}
.vsn-cmp__label{font-weight:700;color:rgba(255,255,255,.55);flex:0 0 auto;min-width:80px;font-size:13px;text-transform:uppercase;letter-spacing:.04em}
.vsn-cmp__row>span:last-child{text-align:right}
.vsn-cmp__link{display:inline-flex;align-items:center;gap:6px;margin-top:1rem;font-size:14.5px;font-weight:600;color:var(--accent-glow);text-decoration:none;transition:color var(--trans),gap var(--trans)}
.vsn-cmp__link:hover{color:#fff;gap:10px}
.vsn-cmp__link svg{transition:transform .25s}
.vsn-cmp__link:hover svg{transform:rotate(45deg)}

.vsn-cmp-note{display:flex;align-items:flex-start;gap:.85rem;margin-top:2rem;padding:1.25rem 1.5rem;border-radius:var(--r);background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16)}
.vsn-cmp-note svg{flex-shrink:0;color:var(--accent-glow);margin-top:.15rem}
.vsn-cmp-note p{font-size:15px;line-height:1.65;color:rgba(255,255,255,.88);margin:0}

@media(max-width:991px){.vsn-compare{grid-template-columns:1fr;max-width:560px;margin-inline:auto}}
@media(max-width:575px){
  .vsn-cmp{padding:1.35rem 1.15rem}
  .vsn-cmp__head h3{font-size:17px}
  .vsn-cmp__row{font-size:13px}
  .vsn-cmp__label{font-size:11.5px;min-width:70px}
  .vsn-cmp-note{padding:1rem}
  .vsn-cmp-note p{font-size:13.5px}
}


/* ─── RISK CARDS ─── */
.vsn-risk-card{padding:1.75rem 1.5rem;border-radius:var(--rl);background:var(--white);border:1px solid var(--line);height:100%;transition:box-shadow var(--trans),border-color var(--trans),transform var(--trans)}
.vsn-risk-card:hover{box-shadow:var(--sh-lift);border-color:rgba(180,83,9,.15);transform:translateY(-2px)}
.vsn-risk-card__ic{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;background:var(--amber-s);color:var(--amber);margin-bottom:1rem}
.vsn-risk-card h3{font-size:17px;font-weight:700;color:var(--ink);margin:0 0 .5rem;letter-spacing:-.02em}
.vsn-risk-card p{font-size:14.5px;line-height:1.65;color:var(--muted);margin:0}

@media(max-width:575px){
  .vsn-risk-card{padding:1.25rem 1.1rem}
  .vsn-risk-card__ic{width:36px;height:36px;margin-bottom:.75rem}
  .vsn-risk-card h3{font-size:15px}
  .vsn-risk-card p{font-size:13px}
}


/* ─── WARN LIST ─── */
.vsn-warn-list{display:flex;flex-direction:column;gap:0;border-radius:var(--rl);overflow:hidden;background:var(--white);border:1px solid var(--line);box-shadow:var(--sh),0 6px 24px rgba(9,13,26,.05)}
.vsn-warn{display:flex;align-items:flex-start;gap:.75rem;padding:1rem 1.15rem;border-bottom:1px solid var(--line);transition:background var(--trans)}
.vsn-warn:last-child{border-bottom:none}
.vsn-warn:hover{background:rgba(180,83,9,.015)}
.vsn-warn__ic{width:34px;height:34px;flex:0 0 34px;border-radius:9px;display:flex;align-items:center;justify-content:center;background:var(--amber-s);color:var(--amber);margin-top:2px}
.vsn-warn__ic svg{display:block;width:16px;height:16px;margin:0}
.vsn-warn strong{display:block;font-size:14.5px;font-weight:700;color:var(--ink);margin-bottom:.15rem}
.vsn-warn>div>span{display:block;font-size:13.5px;line-height:1.5;color:var(--muted)}

@media(max-width:575px){
  .vsn-warn{padding:.85rem .9rem;gap:.6rem}
  .vsn-warn__ic{width:30px;height:30px;flex:0 0 30px}
  .vsn-warn__ic svg{width:14px;height:14px}
  .vsn-warn strong{font-size:13.5px}
  .vsn-warn>div>span{font-size:12px}
}


/* ─── RELATED GRID ─── */
.vsn-related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.125rem;margin-top:1rem}
.vsn-related-grid .svc-card{grid-column:auto!important}

@media(max-width:991px){.vsn-related-grid{display:flex;flex-wrap:wrap;justify-content:center}
  .vsn-related-grid .svc-card{width:calc(50% - .5625rem)}}
@media(max-width:575px){.vsn-related-grid .svc-card{width:100%}}


/* ─── DISCLAIMER ─── */
.vsn-disc-sec{padding:clamp(2rem,3vw,3rem) 0}
.vsn-disclaimer{padding:1.15rem 1.35rem;border-radius:var(--r);background:var(--bg);border-left:4px solid var(--line);font-size:13.5px;line-height:1.6;color:var(--light)}
.vsn-disclaimer p{margin:0}


/* ─── SCROLL REVEAL ─── */
/* Fallback: elements visible by default. Only hide when JS-driven observer is ready. */
@media(prefers-reduced-motion:no-preference){
  .vsn-model-flow__step,
  .vsn-model-flow__connector,
  .vsn-keybox,
  .vsn-dual__card,
  .vsn-trust-strip__item,
  .vsn-timeline__step,
  .vsn-timeline__note,
  .vsn-legal-item,
  .vsn-info-box,
  .vsn-pozor-comp__img,
  .vsn-pozor-comp__float,
  .vsn-cmp,
  .vsn-cmp-note,
  .vsn-risk-card,
  .vsn-warn,
  .vsn-disclaimer{
    opacity:0;
    transform:translateY(12px);
    transition:opacity .55s cubic-bezier(.16,1,.3,1),transform .55s cubic-bezier(.16,1,.3,1);
    /* Safety: auto-reveal after 1.5s even if observer fails */
    animation:vsn-reveal .55s 1.5s cubic-bezier(.16,1,.3,1) forwards;
  }

  /* When observer fires, cancel the fallback animation and reveal immediately */
  .sec.is-vis .vsn-model-flow__step,
  .sec.is-vis .vsn-model-flow__connector,
  .sec.is-vis .vsn-keybox,
  .sec.is-vis .vsn-dual__card,
  .sec.is-vis .vsn-trust-strip__item,
  .sec.is-vis .vsn-timeline__step,
  .sec.is-vis .vsn-timeline__note,
  .sec.is-vis .vsn-legal-item,
  .sec.is-vis .vsn-info-box,
  .sec.is-vis .vsn-pozor-comp__img,
  .sec.is-vis .vsn-pozor-comp__float,
  .sec.is-vis .vsn-cmp,
  .sec.is-vis .vsn-cmp-note,
  .sec.is-vis .vsn-risk-card,
  .sec.is-vis .vsn-warn,
  .sec.is-vis .vsn-disclaimer{
    opacity:1;
    transform:translateY(0);
    animation:none;
  }

  @keyframes vsn-reveal{to{opacity:1;transform:translateY(0)}}

  /* Also protect global sec-hd headings that are opacity:0 from style.css */
  .sec .sec-hd{animation:vsn-reveal .55s 1.5s cubic-bezier(.16,1,.3,1) forwards}
  .sec.is-vis .sec-hd{animation:none}

  /* stagger delays */
  .vsn-model-flow__step:nth-child(3){transition-delay:.06s}
  .vsn-model-flow__step:nth-child(5){transition-delay:.12s}
  .vsn-dual__card:nth-child(2){transition-delay:.06s}
  .vsn-trust-strip__item:nth-child(2){transition-delay:.06s}
  .vsn-trust-strip__item:nth-child(3){transition-delay:.12s}
  .vsn-timeline__step:nth-child(2){transition-delay:.06s}
  .vsn-timeline__step:nth-child(3){transition-delay:.12s}
  .vsn-timeline__step:nth-child(4){transition-delay:.18s}
  .vsn-timeline__step:nth-child(5){transition-delay:.24s}
  .vsn-timeline__step:nth-child(6){transition-delay:.3s}
  .vsn-legal-item:nth-child(2){transition-delay:.06s}
  .vsn-legal-item:nth-child(3){transition-delay:.12s}
  .vsn-legal-item:nth-child(4){transition-delay:.18s}
  .vsn-legal-item:nth-child(5){transition-delay:.24s}
  .vsn-legal-item:nth-child(6){transition-delay:.3s}
  .vsn-cmp:nth-child(2){transition-delay:.06s}
  .vsn-cmp:nth-child(3){transition-delay:.12s}
  .vsn-risk-card:nth-child(2){transition-delay:.06s}
  .vsn-risk-card:nth-child(3){transition-delay:.12s}
  .vsn-warn:nth-child(2){transition-delay:.06s}
  .vsn-warn:nth-child(3){transition-delay:.12s}
  .vsn-warn:nth-child(4){transition-delay:.18s}
}

/**/

.ed-photo{
  width:100%;
}

.ed-photo__media{
  display:block;
  width:100%;
  overflow:hidden;
  border-radius:32px;
  box-shadow:0 12px 40px rgba(9,13,26,.10);
  background:var(--white);
}

.ed-photo__media img{
  display:block;
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
}

@media (max-width: 991.98px){
  .ed-photo{
    max-width:680px;
    margin:0 auto;
  }

  .ed-photo__media{
    border-radius:24px;
  }
}

.vsn-pozor-comp__media{
  display:block;
  width:100%;
}

.vsn-pozor-comp__media img{
  display:block;
  width:100%;
  aspect-ratio:3/4;
  object-fit:cover;
}

.vsn-living-photo{
  width:100%;
}

.vsn-living-photo__media{
  display:block;
  width:100%;
  overflow:hidden;
  border-radius:var(--rl);
  box-shadow:0 12px 40px rgba(9,13,26,.1);
  background:var(--white);
}

.vsn-living-photo__media img{
  display:block;
  width:100%;
  aspect-ratio:16/10;
  object-fit:cover;
}