/* ============================================================
   VIVO Residence 1 — shared stylesheet
   Editorial (light, default) + Architectural (dark) themes.
   Buildless: plain CSS, design tokens via custom properties.
   ============================================================ */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Hanken Grotesk',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  background:var(--page);color:var(--text);
}
::selection{background:#7D826A;color:#EFE4D0}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{font-family:inherit}

/* ---- Design tokens: Editorial (light) ---- */
:root{
  --page:#EFE4D0; --surface:#FAF5EA; --surface-alt:#E5D9C2;
  --text:#2C2925; --text-2:#6B6863; --text-3:#B4B2AE;
  --line:#B5A992; --accent:#7D826A; --accent-h:#5F6451;
  --invert-bg:#2C2925; --invert-text:#EFE4D0; --invert-text-2:#B5A992;
  --display:'Cormorant Garamond',Georgia,serif; --tt:none; --ls:0em;
  --pad-y:clamp(72px,9vw,140px); --pad-x:clamp(20px,6vw,96px);
}
/* ---- Night (dark) — same typography as Day, only the color scheme changes ---- */
[data-theme="arch"]{
  --page:#2C2925; --surface:#3D3A36; --surface-alt:#26231F;
  --text:#EFE4D0; --text-2:#B4B2AE; --text-3:#6B6863;
  --line:#6B6863; --accent:#97A48F; --accent-h:#B5A992;
  --invert-bg:#EFE4D0; --invert-text:#2C2925; --invert-text-2:#6B6863;
}

@keyframes vivoUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
@keyframes vivoFade{from{opacity:0}to{opacity:1}}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

.wrap{min-height:100vh;background:var(--page);color:var(--text)}

/* ---- Nav ---- */
.nav{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;
  gap:16px;padding:18px var(--pad-x);background:color-mix(in srgb,var(--page) 88%,transparent);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.nav-brand{display:flex;flex-direction:column;line-height:1;cursor:pointer}
.nav-brand .wm{font-family:var(--display);font-weight:600;font-size:26px;letter-spacing:0.12em}
.nav-brand .sub{font-size:10px;letter-spacing:0.34em;text-transform:uppercase;color:var(--accent);margin-top:3px}
.nav-links{display:flex;align-items:center;gap:clamp(14px,2.4vw,38px)}
.nav-links a{font-size:13.5px;letter-spacing:0.04em;color:var(--text-2);transition:color .2s ease}
.nav-links a:hover{color:var(--text)}
.nav-actions{display:flex;align-items:center;gap:10px}
.nav-btn{cursor:pointer;background:transparent;border:1px solid var(--line);color:var(--text-2);
  font-size:11px;letter-spacing:0.08em;text-transform:uppercase;padding:8px 12px;border-radius:2px;transition:all .2s ease}
.nav-btn:hover{border-color:var(--accent);color:var(--text)}
.nav-btn--solid{background:var(--text);border:none;color:var(--page);font-weight:600;letter-spacing:0.1em;padding:8px 13px}

/* ---- Section primitives ---- */
.sec{padding:var(--pad-y) var(--pad-x)}
.sec--surface{background:var(--surface)}
.sec--invert{background:var(--invert-bg);color:var(--invert-text)}
.kicker{font-size:12px;letter-spacing:0.28em;text-transform:uppercase;color:var(--accent);margin-bottom:16px}
.kicker--inv{color:var(--invert-text-2)}
.h2{font-family:var(--display);font-weight:500;font-size:clamp(2rem,3.6vw,3.4rem);line-height:1.08;
  text-transform:var(--tt);letter-spacing:var(--ls)}
.lead{margin-top:20px;font-size:16px;line-height:1.7;color:var(--text-2)}

/* ---- Hero ---- */
.hero{position:relative;min-height:92vh;display:flex;align-items:flex-end;overflow:hidden;background:#2C2925}
.hero__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero__grad{position:absolute;inset:0;background:linear-gradient(180deg,rgba(44,41,37,0.30) 0%,rgba(44,41,37,0.10) 40%,rgba(44,41,37,0.85) 100%)}
.hero__tag-tl{position:absolute;top:26px;right:var(--pad-x);font-family:ui-monospace,monospace;
  font-size:clamp(14px,1.3vw,19px);font-weight:600;letter-spacing:0.3em;color:#EFE4D0;
  padding-bottom:8px;border-bottom:1px solid rgba(239,228,208,0.55)}
.hero__content{position:relative;padding:0 var(--pad-x) clamp(56px,7vw,96px);max-width:1100px;animation:vivoUp .9s ease both}
.hero__tagline{font-family:var(--display);font-style:italic;font-weight:600;font-size:clamp(30px,3.6vw,50px);
  line-height:1.05;color:#EFE4D0;text-shadow:0 3px 22px rgba(44,41,37,0.7);margin-bottom:18px}
.hero__h1{font-family:var(--display);font-weight:500;color:#EFE4D0;font-size:clamp(3rem,7vw,6.4rem);
  line-height:0.98;text-transform:var(--tt);letter-spacing:var(--ls)}
.hero__h1 em{font-style:italic;font-weight:400}
.hero__sub{margin-top:26px;max-width:560px;font-size:clamp(15px,1.3vw,17px);line-height:1.65;color:rgba(239,228,208,0.85)}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:14px;letter-spacing:0.03em;
  padding:15px 28px;border-radius:2px;cursor:pointer;transition:all .25s ease}
.btn--cream{background:#EFE4D0;color:#2C2925;border:1px solid #EFE4D0}
.btn--cream:hover{background:#fff}
.btn--ghost{border:1px solid rgba(239,228,208,0.55);color:#EFE4D0;font-weight:500}
.btn--ghost:hover{border-color:#EFE4D0}
.btn--solid{background:var(--text);color:var(--page);border:none}
.btn--solid:hover{background:var(--accent-h);color:#fff}

/* ---- Stats strip ---- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);border-bottom:1px solid var(--line)}
.stat{padding:clamp(30px,4vw,52px) clamp(18px,2.5vw,40px);border-right:1px solid var(--line)}
.stat:last-child{border-right:none}
.stat__num{font-family:var(--display);font-weight:500;font-size:clamp(2.2rem,4vw,3.4rem);line-height:1;color:var(--accent)}
.stat__lbl{margin-top:8px;font-size:13px;letter-spacing:0.04em;color:var(--text-2)}

/* ---- Despre (two-col stretch) ---- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,90px);align-items:stretch}
.split__media{min-height:460px;border:1px solid var(--line);overflow:hidden}
.split__media img{width:100%;height:100%;object-fit:cover}
.prose{margin-top:32px;font-size:19px;line-height:1.85;color:var(--text-2);max-width:50ch}
.prose + .prose{margin-top:24px}

/* ---- Case / models ---- */
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-bottom:clamp(36px,5vw,64px)}
.sec-head__intro{max-width:34ch;font-size:15px;line-height:1.6;color:var(--text-2)}
.models{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,2.4vw,36px)}
.house-card{background:var(--page);border:1px solid var(--line);display:flex;flex-direction:column;
  cursor:pointer;transition:transform .4s ease,box-shadow .4s ease}
.house-card:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(44,41,37,0.14)}
.house-card__img{aspect-ratio:16/11;overflow:hidden;border-bottom:1px solid var(--line);position:relative;
  background-color:var(--surface-alt);background-size:cover;background-position:center}
.badge{position:absolute;top:14px;left:14px;background:color-mix(in srgb,var(--invert-bg) 82%,transparent);
  color:var(--invert-text);font-size:11px;letter-spacing:0.08em;text-transform:uppercase;padding:6px 12px;border-radius:2px}
.house-card__body{padding:clamp(24px,2.5vw,34px)}
.house-card__name{font-family:var(--display);font-weight:600;font-size:30px;text-transform:var(--tt);letter-spacing:var(--ls)}
.house-card__desc{margin-top:10px;font-size:15px;line-height:1.6;color:var(--text-2);max-width:40ch}
.specs{display:flex;gap:18px;margin-top:22px;flex-wrap:wrap}
.spec__v{font-family:var(--display);font-size:22px;color:var(--accent)}
.spec__l{font-size:12px;color:var(--text-2);margin-top:2px}
.house-card__foot{margin-top:24px;padding-top:20px;border-top:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.price__from{font-size:12px;letter-spacing:0.06em;color:var(--text-2)}
.price__val{font-family:var(--display);font-weight:600;font-size:26px;color:var(--text)}
.price__vat{font-size:11px;color:var(--text-2);margin-left:8px}
.btn--accent{background:var(--accent);color:#fff;font-size:13px;letter-spacing:0.05em;font-weight:600;
  padding:12px 22px;border-radius:2px;box-shadow:0 6px 18px color-mix(in srgb,var(--accent) 40%,transparent);border:none}
.btn--accent:hover{background:var(--accent-h)}

/* ---- Interioare mosaic ---- */
.intro-block{max-width:60ch;margin-bottom:clamp(36px,5vw,60px)}
.mosaic{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:clamp(150px,13vw,210px);gap:clamp(10px,1.2vw,16px)}
.tile{position:relative;overflow:hidden;border:1px solid var(--line);background-color:var(--surface-alt);
  background-size:cover;background-position:center}
.tile figcaption{position:absolute;left:0;right:0;bottom:0;padding:14px 16px;
  background:linear-gradient(180deg,transparent,rgba(44,41,37,0.7));color:#EFE4D0;font-size:12px;letter-spacing:0.06em}

/* ---- Facilitati ---- */
.fac-grid{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--line);border-left:1px solid var(--line)}
.fac{padding:clamp(26px,3vw,40px);border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
.fac__no{font-family:var(--display);font-size:15px;color:var(--accent)}
.fac__t{margin-top:16px;font-size:19px;font-weight:600;letter-spacing:0.01em}
.fac__d{margin-top:10px;font-size:14px;line-height:1.6;color:var(--text-2)}

/* ---- Localizare ---- */
.loc{display:grid;grid-template-columns:1.4fr 1fr;gap:clamp(40px,5vw,80px);align-items:stretch}
.loc__masterplan{grid-column:1/-1;position:relative;border:1px solid var(--line);overflow:hidden;margin-bottom:clamp(10px,1.6vw,22px)}
.loc__masterplan img{width:100%;display:block}
.loc__mp-cap{position:absolute;left:0;bottom:0;padding:10px 16px;background:linear-gradient(90deg,rgba(44,41,37,0.72),transparent);
  color:#EFE4D0;font-family:ui-monospace,monospace;font-size:11px;letter-spacing:0.12em}
.loc__map{min-height:340px;border:1px solid var(--line);overflow:hidden;position:relative}
.loc__map iframe{width:100%;height:100%;border:0;display:block}
.loc__times{margin-top:22px}
.time-row{display:flex;align-items:baseline;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:1px solid var(--line)}
.time-row__l{font-size:14px;color:var(--text)}
.time-row__v{font-family:var(--display);font-weight:600;font-size:18px;color:var(--accent);flex-shrink:0}

/* ---- Tehnic (dark) ---- */
.specs-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0 clamp(40px,6vw,90px)}
.spec-row{display:flex;align-items:baseline;justify-content:space-between;gap:24px;padding:20px 0;
  border-bottom:1px solid color-mix(in srgb,var(--invert-text) 22%,transparent)}
.spec-row__l{font-size:13px;letter-spacing:0.04em;text-transform:uppercase;color:var(--invert-text-2);flex-shrink:0}
.spec-row__v{font-size:15px;line-height:1.4;text-align:right}

/* ---- Contact / form ---- */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,90px)}
.contact__email{font-family:var(--display);font-size:22px;color:var(--accent)}
.contact__phone{font-size:15px;color:var(--text-2)}
.form{display:flex;flex-direction:column;gap:16px}
.form input:not([type=checkbox]){background:var(--surface);border:1px solid var(--line);color:var(--text);font-family:inherit;
  font-size:14px;padding:15px 16px;border-radius:2px;outline:none;transition:border-color .2s ease;width:100%}
.form input:not([type=checkbox]):focus{border-color:var(--accent)}
.form__row2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form__role-lbl{font-size:12px;letter-spacing:0.04em;color:var(--text-2);margin-bottom:10px}
.roles{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.role-chip{cursor:pointer;padding:12px 10px;border:1px solid var(--line);background:var(--surface);color:var(--text-2);
  font-family:inherit;font-size:13px;border-radius:2px;text-align:center;transition:all .2s ease}
.role-chip[aria-pressed="true"]{border-color:var(--accent);background:var(--accent);color:#fff}
.gdpr{display:flex;align-items:flex-start;gap:10px;font-size:12.5px;line-height:1.5;color:var(--text-2);cursor:pointer}
.gdpr input{width:16px;height:16px;margin-top:2px;accent-color:var(--accent);flex-shrink:0}
.form__note{font-size:12px;color:var(--text-2);text-align:center}
.form__ok{display:none;background:color-mix(in srgb,var(--accent) 12%,transparent);border:1px solid var(--accent);
  color:var(--text);padding:16px;border-radius:2px;font-size:14px;line-height:1.6}
.form__ok.show{display:block;animation:vivoFade .4s ease both}
.form__err{display:none;background:color-mix(in srgb,#8B3A3A 10%,transparent);border:1px solid #8B3A3A;
  color:var(--text);padding:16px;border-radius:2px;font-size:14px;line-height:1.6}
.form__err.show{display:block}

/* ---- Footer ---- */
.foot{background:var(--invert-bg);color:var(--invert-text);padding:clamp(56px,7vw,90px) var(--pad-x) 40px}
.foot__top{display:flex;justify-content:space-between;flex-wrap:wrap;gap:40px;padding-bottom:48px;
  border-bottom:1px solid color-mix(in srgb,var(--invert-text) 22%,transparent)}
.foot__wm{font-family:var(--display);font-weight:600;font-size:32px;letter-spacing:0.12em}
.foot__tag{font-family:var(--display);font-style:italic;font-size:18px;color:var(--invert-text-2);margin-top:8px}
.foot__cols{display:flex;gap:clamp(40px,6vw,90px);flex-wrap:wrap}
.foot__col{display:flex;flex-direction:column;gap:12px}
.foot__col-h{font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--invert-text-2)}
.foot__col a,.foot__col span{font-size:14px;color:var(--invert-text)}
.foot__col a:hover{color:var(--invert-text-2)}
.foot__bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-top:24px;font-size:12px;color:var(--invert-text-2)}

/* ---- Detail page ---- */
.dhero{position:relative;min-height:78vh;display:flex;align-items:flex-end;overflow:hidden;background:#2C2925}
.dhero__img{position:absolute;inset:0;background-size:cover;background-position:center}
.dhero__grad{position:absolute;inset:0;background:linear-gradient(180deg,rgba(44,41,37,0.34) 0%,rgba(44,41,37,0.10) 38%,rgba(44,41,37,0.88) 100%)}
.dhero__back{position:absolute;top:26px;left:var(--pad-x);cursor:pointer;background:color-mix(in srgb,#2C2925 55%,transparent);
  border:1px solid rgba(239,228,208,0.45);color:#EFE4D0;font-size:13px;letter-spacing:0.04em;padding:10px 18px;border-radius:2px}
.dhero__content{position:relative;padding:0 var(--pad-x) clamp(48px,6vw,80px);width:100%}
.dhero__badge{display:inline-block;background:color-mix(in srgb,#EFE4D0 16%,transparent);color:#EFE4D0;
  font-size:11px;letter-spacing:0.1em;text-transform:uppercase;padding:7px 14px;border-radius:2px;margin-bottom:18px}
.dhero__h1{font-family:var(--display);font-weight:500;color:#EFE4D0;font-size:clamp(2.6rem,6vw,5.4rem);
  line-height:1;text-transform:var(--tt);letter-spacing:var(--ls)}
.dhero__stats{display:flex;flex-wrap:wrap;gap:clamp(16px,2.6vw,40px);margin-top:30px;align-items:flex-end}
.dstat__v{font-family:var(--display);font-size:clamp(1.6rem,2.4vw,2.2rem);color:#EFE4D0}
.dstat__l{font-size:12px;color:rgba(239,228,208,0.7);margin-top:2px}
.dprice{margin-left:auto;text-align:right}
.dprice__from{font-size:12px;color:rgba(239,228,208,0.7)}
.dprice__val{font-family:var(--display);font-size:clamp(1.8rem,2.8vw,2.6rem);color:#EFE4D0}
.dprice__vat{font-size:11px;color:rgba(239,228,208,0.65);margin-top:2px}
.ddesc{padding:clamp(56px,7vw,110px) var(--pad-x) clamp(32px,4vw,56px);max-width:760px}
.ddesc p{font-family:var(--display);font-style:italic;font-size:clamp(1.4rem,2.4vw,2rem);line-height:1.4;color:var(--text)}
.dgal{padding:clamp(24px,3vw,48px) var(--pad-x) clamp(64px,7vw,120px)}
.dgal__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(clamp(190px,23vw,300px),1fr));gap:clamp(10px,1.2vw,16px)}
.photo{position:relative;aspect-ratio:4/3;overflow:hidden;border:1px solid var(--line);background-color:var(--surface-alt);
  background-size:cover;background-position:center;cursor:zoom-in;transition:opacity .3s ease}
.photo:hover{opacity:0.92}
.photo figcaption{position:absolute;left:0;right:0;bottom:0;padding:10px 12px;
  background:linear-gradient(180deg,transparent,rgba(44,41,37,0.7));color:#EFE4D0;font-size:11px;letter-spacing:0.05em}
.dplans{padding:clamp(64px,7vw,120px) var(--pad-x);background:var(--surface);border-top:1px solid var(--line)}
.dplans__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(clamp(260px,30vw,400px),1fr));gap:clamp(16px,2vw,28px)}
.plan{border:1px solid var(--line);background:#fff;display:flex;flex-direction:column;cursor:zoom-in;transition:box-shadow .3s ease}
.plan:hover{box-shadow:0 12px 30px rgba(44,41,37,0.14)}
.plan__img{aspect-ratio:4/3;background-color:#fff;background-size:contain;background-position:center;background-repeat:no-repeat}
.plan__foot{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-top:1px solid var(--line);background:var(--page)}
.plan__lbl{font-size:14px;font-weight:600;color:var(--text)}
.plan__open{font-size:12px;letter-spacing:0.06em;color:var(--accent);font-weight:600}
.dcta{padding:clamp(64px,7vw,120px) var(--pad-x);display:flex;flex-direction:column;align-items:center;text-align:center;gap:24px}
.dcta h2{max-width:18ch}

/* ---- Lightbox ---- */
.lb{position:fixed;inset:0;z-index:200;background:rgba(20,18,16,0.95);display:none;align-items:center;justify-content:center;
  padding:clamp(16px,4vw,72px);animation:vivoFade .25s ease both}
.lb.show{display:flex}
.lb__img{width:100%;height:100%;background-size:contain;background-position:center;background-repeat:no-repeat;
  filter:drop-shadow(0 24px 70px rgba(0,0,0,0.55))}
.lb__btn{position:fixed;cursor:pointer;border-radius:50%;background:rgba(239,228,208,0.12);
  border:1px solid rgba(239,228,208,0.3);color:#EFE4D0;line-height:1;display:flex;align-items:center;justify-content:center}
.lb__prev{left:clamp(10px,2vw,28px);top:50%;transform:translateY(-50%);width:52px;height:52px;font-size:24px}
.lb__next{right:clamp(10px,2vw,28px);top:50%;transform:translateY(-50%);width:52px;height:52px;font-size:24px}
.lb__close{top:clamp(14px,2vw,28px);right:clamp(14px,2vw,28px);width:46px;height:46px;font-size:18px}
.lb__cap{position:fixed;bottom:clamp(16px,3vw,30px);left:50%;transform:translateX(-50%);
  color:rgba(239,228,208,0.85);font-size:13px;letter-spacing:0.06em}

/* ---- Admin panel ---- */
.admin{position:fixed;inset:0;z-index:150;background:rgba(44,41,37,0.55);display:none;justify-content:flex-end}
.admin.show{display:flex;animation:vivoFade .2s ease both}
.admin__panel{width:min(580px,100%);height:100%;background:var(--page);color:var(--text);overflow-y:auto;box-shadow:-20px 0 60px rgba(0,0,0,0.3)}
.admin__head{position:sticky;top:0;background:var(--page);border-bottom:1px solid var(--line);padding:20px 24px;
  display:flex;align-items:flex-start;justify-content:space-between;gap:16px;z-index:2}
.admin__title{font-family:var(--display);font-size:23px;font-weight:600}
.admin__hint{font-size:12px;line-height:1.5;color:var(--text-2);margin-top:5px;max-width:42ch}
.admin__tabs{padding:20px 24px 4px;display:flex;gap:8px}
.admin__tab{cursor:pointer;flex:1;padding:11px;border:1px solid var(--line);border-radius:2px;font-family:inherit;
  font-size:13px;font-weight:600;background:transparent;color:var(--text-2);transition:all .2s ease}
.admin__tab[aria-selected="true"]{background:var(--accent);color:#fff;border-color:var(--accent)}
.admin__sec{padding:16px 24px 4px}
.admin__sec-h{font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--accent);margin-bottom:12px}
.admin__grid2{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.admin__item{border:1px solid var(--line);background:var(--surface)}
.admin__thumb{aspect-ratio:4/3;background-color:var(--surface-alt);background-size:cover;background-position:center}
.admin__item-foot{display:flex;align-items:center;justify-content:space-between;padding:6px 8px;gap:4px}
.admin__cap{font-size:11px;color:var(--text-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.admin__btns{display:flex;gap:3px;flex-shrink:0}
.admin__mini{cursor:pointer;width:25px;height:25px;border:1px solid var(--line);background:var(--page);color:var(--text);border-radius:2px;font-size:13px;line-height:1}
.admin__mini--del{color:#8B3A3A;font-size:12px}
.admin__actions{padding:16px 24px;display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.admin__upload{cursor:pointer;background:var(--text);color:var(--page);font-size:13px;font-weight:600;padding:11px 16px;border-radius:2px}
.admin__reset{cursor:pointer;background:transparent;border:1px solid var(--line);color:var(--text-2);font-family:inherit;font-size:13px;padding:11px 16px;border-radius:2px}
.admin__lib{padding:4px 24px 32px}
.admin__grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.lib-item{cursor:pointer;padding:0;border:1px solid var(--line);background-color:var(--surface-alt);
  background-size:cover;background-position:center;aspect-ratio:4/3;border-radius:2px;position:relative}
.lib-item__plus{position:absolute;right:4px;bottom:4px;width:22px;height:22px;border-radius:50%;background:var(--accent);
  color:#fff;font-size:15px;line-height:22px;text-align:center}

/* ============================================================
   Overflow / shrink fixes — prevent sideways scroll on mobile
   (grid/flex items default to min-width:auto and won't shrink
   below image/iframe/long-text intrinsic size)
   ============================================================ */
html,body{overflow-x:clip;max-width:100%}
iframe{max-width:100%}
.split>*,.loc>*,.contact>*,.contact>form>*,.form__row2>*,.dhero__stats>*,.sec-head>*{min-width:0}
.split__media,.loc__map,.loc__masterplan{min-width:0}
.gdpr{min-width:0}
.gdpr span{min-width:0;overflow-wrap:anywhere}
.hero__content,.dhero__content{max-width:100%}

/* ============================================================
   Responsive — stack grids under 720px (prototype had none)
   ============================================================ */
@media(max-width:980px){
  .nav-links{display:none}
  .loc{grid-template-columns:1fr}
  .loc__map{min-height:0;height:auto;width:100%;aspect-ratio:4/3}
}
@media(max-width:720px){
  .stats{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(2n){border-right:none}
  .split,.contact{grid-template-columns:1fr}
  .split__media{min-height:0;height:auto;width:100%;aspect-ratio:3/2}
  .models{grid-template-columns:1fr}
  .mosaic{grid-template-columns:repeat(2,1fr);grid-auto-rows:clamp(140px,40vw,200px)}
  .tile{grid-column:span 1!important;grid-row:span 1!important}
  .fac-grid{grid-template-columns:1fr}
  .specs-grid{grid-template-columns:1fr}
  .form__row2{grid-template-columns:1fr}
  .dprice{margin-left:0;text-align:left;width:100%}
}
@media(max-width:480px){
  .stats{grid-template-columns:1fr}
  .stat{border-right:none}
  .roles{grid-template-columns:1fr}
}
