*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--blue:#1f427d;--blue-tint:#eef2f8;--blue-tint-hover:#dde6f3;--pink:var(--blue);--text:#222;--muted:#767676;--border:#ebebeb;--gray:#bebcbc;--gray-faded:rgba(190,188,188,0.4)}
body{font-family:'Figtree',sans-serif;color:var(--text);height:100vh;overflow:hidden;display:flex;flex-direction:column}
body.page-bygning{height:auto;overflow:auto;display:block;background:#fff}

/* ── HEADER ─────────────────────────────────────── */
.header{height:71px;background:#fff;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 60px;justify-content:space-between;flex-shrink:0;z-index:1000;position:relative}
.logo{display:flex;align-items:center;gap:6px;text-decoration:none}
.logo-icon{width:38px;height:38px;flex-shrink:0}
.logo-wordmark{display:flex;align-items:flex-start;gap:1px}
.logo-name{color:var(--pink);font-size:23.2px;font-weight:700;letter-spacing:-0.92px;line-height:1}
.logo-copy{color:var(--pink);font-size:8.5px;font-weight:700;margin-top:1px}
.user{display:flex;align-items:center;gap:10px}
.user-name{font-size:14px;color:#1f427d}
.user-avatar{width:35px;height:35px;border-radius:50%;background:#1f427d;display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:600;flex-shrink:0}
.btn-log-ud{display:inline-flex;align-items:center;justify-content:center;padding:7px 8px 6px;border:2px solid #1f427d;border-radius:30px;color:#1f427d;font-family:'Figtree',sans-serif;font-size:11px;font-weight:600;line-height:1;text-decoration:none;background:transparent;cursor:pointer;white-space:nowrap;transition:background 0.15s,color 0.15s;margin-right:14px}
.btn-log-ud:hover{background:#1f427d;color:#fff}

/* ── FILTER BAR ──────────────────────────────────── */
.filter-bar{position:absolute;top:18px;left:0;right:0;height:72px;background:transparent;display:flex;align-items:center;padding:0 60px;gap:16px;z-index:999;pointer-events:none}
.filter-bar > *{pointer-events:auto}
.search-wrap{position:relative;flex-shrink:1;width:450px;min-width:370px;height:48px;border-radius:24px;background:#fff;box-shadow:0 10px 15px rgba(0,0,0,0.05)}
.search-input{width:100%;height:100%;border:none;border-radius:24px;padding:0 52px 0 20px;font-size:15px;color:var(--text);font-family:inherit;outline:none;background:transparent;letter-spacing:-0.25px}
.search-input::placeholder{color:rgba(118,118,118,0.6)}
.search-btn{position:absolute;right:8px;top:8px;width:32px;height:32px;border-radius:50%;background:var(--blue);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center}
.search-clear{position:absolute;right:48px;top:50%;transform:translateY(-50%);width:22px;height:22px;border-radius:50%;background:#f2f2f2;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}
.search-clear:hover{background:#e6e6e6}
.search-clear[hidden]{display:none}
.search-input{padding-right:80px}
.dropdown{width:262px;min-width:0;height:48px;border:none;border-radius:24px;padding:0 18px 0 20px;font-size:15px;color:var(--text);font-family:inherit;display:flex;align-items:center;justify-content:space-between;cursor:pointer;background:#fff;flex-shrink:1;position:relative;user-select:none;letter-spacing:-0.25px;box-shadow:0 10px 15px rgba(0,0,0,0.05)}
.dropdown > span:first-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.chevron{width:16px;height:16px;display:flex;align-items:center;justify-content:center;transition:transform 0.2s;flex-shrink:0}
.dropdown.open .chevron{transform:rotate(180deg)}
.dropdown-menu{display:none;position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border-radius:4px;box-shadow:0 10px 25px rgba(0,0,0,0.12);z-index:2000;padding:8px 0;font-size:14px}
.dropdown.open .dropdown-menu{display:block}
.dropdown-item{padding:10px 20px;cursor:pointer;color:var(--text)}
.dropdown-item:hover{background:#f5f5f5}
.dropdown--active{box-shadow:0 10px 15px rgba(0,0,0,0.05),0 0 0 2px var(--blue)}
.dd-clear{display:none;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;border:none;background:rgba(31,66,125,0.12);color:var(--blue);cursor:pointer;flex-shrink:0;padding:0}
.dd-clear:hover{background:rgba(31,66,125,0.22)}
.dropdown--active .dd-clear{display:flex}
.dropdown--active .chevron{display:none}

/* ── MATERIALS DROPDOWN (multi-select checkboxes) ─ */
.materials-menu{padding:20px 22px;max-height:80vh;overflow-y:auto;width:480px;left:0;right:auto}
.dropdown.open .materials-menu{display:grid;grid-template-columns:1fr 1fr;gap:20px 32px}
.mat-group h5{font-size:11px;font-weight:600;color:var(--muted);margin:0 0 8px;letter-spacing:0.06em;text-transform:uppercase;white-space:nowrap}
.mat-check{display:flex;align-items:center;gap:10px;padding:4px 0;cursor:pointer;font-size:14px;color:var(--text);letter-spacing:-0.2px;line-height:1.2}
.mat-check input{appearance:none;-webkit-appearance:none;width:18px;height:18px;border:1.5px solid #c5c5c5;border-radius:3px;background:#fff;cursor:pointer;margin:0;display:inline-flex;align-items:center;justify-content:center;position:relative;flex-shrink:0}
.mat-check input:hover{border-color:#888}
.mat-check input:checked{border-color:var(--text)}
.mat-check input:checked::after{content:'';width:10px;height:6px;border-left:1.6px solid var(--text);border-bottom:1.6px solid var(--text);transform:rotate(-45deg) translate(1px,-1px)}

/* ── MAP AREA ────────────────────────────────────── */
.map-area{flex:1;position:relative;overflow:hidden}
#gl-map{position:absolute;inset:0;z-index:0}
#map{position:relative;width:100%;height:100%;z-index:1;background:transparent!important}
.leaflet-container{background:transparent!important}
.leaflet-control-zoom{display:none!important}
.leaflet-marker-pane,.leaflet-overlay-pane,.leaflet-shadow-pane,.leaflet-markersAboveGL-pane{z-index:650!important}

/* ── SIDEBAR ─────────────────────────────────────── */
.sidebar{position:absolute;left:60px;top:108px;width:370px;z-index:500}
.sidebar-card{background:#fff;border-radius:6px;overflow:hidden;box-shadow:0 10px 10px rgba(0,0,0,0.05)}
.sidebar-card-head{background:var(--blue);display:flex;flex-direction:column;justify-content:center;padding:14px 24px;color:#fff}
.sidebar-card-head-row{display:flex;align-items:center;gap:8px;width:100%}
.sidebar-card-head-icon{width:20px;height:20px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.sidebar-card-head-label{font-size:15px;font-weight:500;letter-spacing:-0.25px;line-height:1.1;padding-top:2px}
.sidebar-card-head-count{margin-left:auto;font-size:32px;font-weight:700;line-height:1}
.reset-chip{align-self:flex-start;margin-left:28px;margin-top:2px;display:inline-flex;align-items:center;gap:5px;background:rgba(255,255,255,0.18);border:none;border-radius:20px;padding:3px 8px 3px 10px;font-size:12px;font-family:inherit;color:#fff;cursor:pointer;letter-spacing:-0.1px;line-height:1}
.reset-chip:hover{background:rgba(255,255,255,0.28)}
.reset-chip[hidden]{display:none}
.sidebar-card-body{padding:20px 24px 24px}
.sidebar-card-divider{height:1px;background:var(--border);margin:22px 0}
.match-rec{margin-top:14px;font-size:14px;line-height:1.2;color:var(--blue);letter-spacing:-0.25px;background:#eff2f6;border-radius:4px;padding:14px 16px}
.match-rec[hidden]{display:none}
.match-rec strong{font-weight:600}

/* ── MATCH PANEL ─────────────────────────────────── */
.match-label{display:block;font-size:15px;font-weight:500;color:var(--text);letter-spacing:-0.25px;margin-bottom:10px;line-height:1}
.match-input{position:relative;width:100%;height:48px}
.match-input input{width:100%;height:100%;border:1px solid #dedada;border-radius:4px;background:#fff;padding:0 44px 0 16px;font-family:inherit;font-size:15px;color:var(--muted);letter-spacing:-0.25px;outline:none;cursor:pointer}
.match-input input:focus{border-color:var(--pink)}
.match-input-icon{position:absolute;right:12px;top:50%;transform:translateY(-50%);width:22px;height:22px;display:flex;align-items:center;justify-content:center;background:none;border:none;padding:0;cursor:pointer}

/* ── DATE PICKER ─────────────────────────────────── */
.date-picker{display:none;position:fixed;background:#fff;border-radius:4px;box-shadow:0 3px 20px rgba(0,0,0,0.15);padding:22px 24px 20px;z-index:1500}
.date-picker.open{display:block}
.date-picker-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.date-picker-year{font-size:18px;font-weight:600;color:var(--text);letter-spacing:-0.25px}
.date-picker-nav{width:32px;height:32px;border-radius:50%;background:var(--blue-tint);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;font-family:inherit}
.date-picker-nav:hover{background:var(--blue-tint-hover)}
.date-picker-months{display:grid;grid-template-columns:repeat(4,1fr);gap:14px 8px;justify-items:center}
.date-month{width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--text);letter-spacing:-0.25px;border-radius:50%;cursor:pointer;background:none;border:none;font-family:inherit}
.date-month:hover{background:#f5f5f5}
.date-month.selected{background:var(--blue-tint);color:var(--text)}

/* ── HISTOGRAM ───────────────────────────────────── */
.hist-bars{display:flex;align-items:flex-end;height:41px;gap:1.5px}
.hbar{flex:1;border-radius:1px 1px 0 0;transition:background-color 0.12s;min-width:0}
.hbar.past{background:var(--gray-faded)}
.hbar.out{background:var(--gray)}
.hbar.in{background:var(--pink)}
.hist-years{display:flex;position:relative;height:14px;margin-top:3px}
.yr-label{position:absolute;font-size:10px;font-weight:500;color:var(--muted);transform:translateX(-50%)}

/* ── DUAL RANGE SLIDER ───────────────────────────── */
.slider-wrap{position:relative;margin-top:11px;padding:0 0}
.slider-track{height:3px;background:#e0e0e0;border-radius:2px;position:relative;margin:12px 0}
.slider-fill{position:absolute;top:0;height:100%;background:var(--pink);border-radius:2px;pointer-events:none}
.slider-handle{position:absolute;top:50%;transform:translate(-50%,-50%);width:24px;height:24px;border-radius:50%;background:var(--pink);cursor:grab;z-index:10}
.slider-handle:active{cursor:grabbing}
.slider-labels{display:flex;justify-content:space-between;margin-top:8px}
.slider-lbl{font-size:13px;color:var(--blue);letter-spacing:-0.25px}

/* ── SUMMARY BOX ─────────────────────────────────── */
.summary-box{background:#ffefef;border-radius:4px;height:80px;margin-top:16px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--pink)}
.summary-default{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;width:100%}
.summary-rec{display:none;width:100%;height:100%;align-items:center;justify-content:center;gap:20px}
.summary-box.has-rec .summary-default{display:none}
.summary-box.has-rec .summary-rec{display:flex}
.summary-count{font-size:28px;font-weight:700;color:var(--pink);line-height:1}
.summary-text{font-size:15px;font-weight:600;color:var(--pink);line-height:1;letter-spacing:-0.25px;text-align:center}
.summary-rec .rec-left{font-size:15px;line-height:1.4;color:var(--pink);text-align:left}
.summary-rec .rec-left p{margin:0}
.summary-rec .rec-range{font-weight:600}
.summary-rec .rec-divider{width:1px;height:50px;background:rgba(31,66,125,0.3);flex-shrink:0}
.summary-rec .rec-right{display:flex;flex-direction:column;align-items:center;line-height:1}
.summary-rec .rec-count{font-size:28px;font-weight:700;color:var(--pink);line-height:1}
.summary-rec .rec-label{font-size:15px;font-weight:600;color:var(--pink);line-height:1;margin-top:4px}

/* ── RECOMMENDATION VIEW (in match panel) ────────── */
.recommendation{margin-top:24px;display:flex;flex-direction:column;gap:15px}
.recommendation[hidden]{display:none}
.rec-hist-label{font-size:12px;font-weight:500;text-transform:uppercase;color:var(--muted);letter-spacing:0.5px;margin:0}
.rec-slider-wrap{position:relative;height:48px;margin-top:8px}
.rec-line{position:absolute;left:0;right:0;top:11px;height:3px;background:#e0e0e0;border-radius:2px}
.rec-fill{position:absolute;top:11px;height:3px;background:var(--pink);border-radius:2px;pointer-events:none}
.rec-handle{position:absolute;top:0;transform:translateX(-50%);width:24px;height:24px;border-radius:50%;background:var(--pink)}
.rec-handle-lbl{position:absolute;top:30px;transform:translateX(-50%);font-size:12px;font-weight:500;color:var(--pink);text-transform:uppercase;letter-spacing:-0.25px;white-space:nowrap}

/* ── MAP ZOOM CONTROLS ───────────────────────────── */
.map-zoom{position:absolute;right:20px;bottom:25px;display:flex;flex-direction:column;align-items:center;gap:0;z-index:500}
.zoom-btn{width:40px;height:40px;background:#fff;border:1px solid #dee3e4;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:20px;color:var(--text);box-shadow:0 2px 8px rgba(0,0,0,0.07);font-family:inherit;line-height:1}
.zoom-btn:first-child{border-radius:5px 5px 0 0;border-bottom:none}
.zoom-btn:nth-child(3){border-radius:0;border-top:none}
.zoom-btn:hover{background:#f5f5f5}
.zoom-slider{appearance:slider-vertical;-webkit-appearance:slider-vertical;writing-mode:bt-lr;width:40px;height:140px;margin:0;background:#fff;border:1px solid #dee3e4;border-top:none;border-bottom:none;cursor:ns-resize;padding:8px 0;accent-color:var(--pink);box-shadow:0 2px 8px rgba(0,0,0,0.07)}
.zoom-pct{margin-top:8px;background:#fff;border:1px solid #dee3e4;border-radius:4px;padding:4px 8px;font-size:11px;font-weight:500;color:var(--text);box-shadow:0 2px 8px rgba(0,0,0,0.07);letter-spacing:-0.25px;min-width:40px;text-align:center}
.zoom-reset{margin-top:6px;background:#fff;border:1px solid #dee3e4;border-radius:4px;padding:5px 8px;font-size:11px;font-weight:500;color:var(--pink);box-shadow:0 2px 8px rgba(0,0,0,0.07);letter-spacing:-0.25px;cursor:pointer;font-family:inherit;min-width:54px;line-height:1}
.zoom-reset:hover{background:var(--blue-tint)}

/* ── BUILDING MARKER ─────────────────────────────── */
.custom-marker{background:none!important;border:none!important}
.dot-marker{width:8px;height:8px;border-radius:50%;background:var(--pink);cursor:pointer;box-shadow:0 1px 3px rgba(0,0,0,0.25);transition:transform 0.1s,background-color 0.1s}
.dot-marker:hover{transform:scale(1.25)}
.dot-marker.selected{background:var(--text);transform:scale(1.4)}
.mpin{cursor:pointer;filter:drop-shadow(0 2px 4px rgba(0,0,0,0.25));transition:transform 0.1s}
.mpin:hover{transform:scale(1.15)}

/* ── CLUSTER MARKER ──────────────────────────────── */
.cluster-marker{background:none!important;border:none!important}
.cluster-bubble{display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--blue);color:#fff;font-family:'Figtree',sans-serif;font-weight:600;letter-spacing:-0.25px;box-shadow:0 2px 8px rgba(31,66,125,0.35);cursor:pointer}

/* ── POPOVER ─────────────────────────────────────── */
.popover{position:absolute;z-index:700;display:none;pointer-events:auto}
.popover-card{background:#fff;border-radius:4px;filter:drop-shadow(0 10px 7.5px rgba(0,0,0,0.05));width:306px;padding:16px 16px 24px;display:flex;flex-direction:column;gap:24px}
.popover-img{width:274px;height:150px;border-radius:4px;overflow:hidden;background:#f2f2f2;flex-shrink:0}
.popover-img img{width:100%;height:100%;object-fit:cover;display:block}
.popover-info{display:flex;flex-direction:column;gap:16px;width:274px}
.popover-text{display:flex;flex-direction:column;gap:8px;color:var(--text)}
.popover-title{font-size:17px;font-weight:600;line-height:1.4;letter-spacing:-0.25px;color:var(--text);margin:0}
.popover-details{display:flex;flex-direction:column}
.popover-details p{font-size:15px;line-height:1.4;color:var(--text);margin:0;letter-spacing:-0.25px}
.popover-link{display:inline-flex;align-items:center;gap:5px;font-size:15px;color:var(--pink);text-decoration:none;line-height:1.4;letter-spacing:-0.25px}
.popover-link:hover{text-decoration:underline}

/* ════════════════════════════════════════════════════════════════════════
   BYGNING PAGE (bygning.html)
   ════════════════════════════════════════════════════════════════════════ */
.bygning-page{padding:0;max-width:none;margin:0}
.bygning-page .page-content{width:1168px;max-width:1168px;margin:0 auto;padding:0}

/* ── GALLERY ─────────────────────────────────────── */
/* Frame 971:9711: hero 1152 / side 560, gap 16, height 660; side = thumbs 387 + gap 16 + map 257 */
.gallery{display:flex;gap:16px;height:660px;margin-bottom:24px;overflow:hidden}
.gallery-main{flex:1152 1 0;background:#222;border-radius:4px;overflow:hidden;position:relative}
.gallery-main img{width:100%;height:100%;object-fit:cover;display:block}
.back-to-map{position:absolute;top:29px;left:max(16px, calc((100vw - 1168px) / 2));background:var(--blue);border-radius:30px;display:flex;align-items:center;gap:6px;padding:13px 16px 13px 14px;font-size:16px;font-weight:500;color:#fff;text-decoration:none;letter-spacing:-0.25px;z-index:2}
.back-to-map:hover{background:#193660}
.gallery-side{flex:560 1 0;display:flex;flex-direction:column;gap:16px;min-width:0}
.gallery-thumbs{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:16px}
.gallery-thumb{background:#e9e6e6;border-radius:4px;overflow:hidden;position:relative;min-height:0}
.gallery-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.gallery-thumb-more::before{content:'';position:absolute;inset:0;background:rgba(0,0,0,0.54);z-index:1}
.gallery-more-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;z-index:2}
.see-images{position:absolute;top:50%;left:50%;right:auto;transform:translate(-50%,-50%);z-index:3;background:#fff;border:none;border-radius:30px;display:flex;align-items:center;gap:8px;padding:12px 16px;font-size:16px;font-weight:500;color:#000;cursor:pointer;font-family:inherit;text-decoration:none;box-shadow:0 2px 8px rgba(0,0,0,0.12);white-space:nowrap;flex-shrink:0}
.see-images:hover{background:#f5f5f5}
.gallery-map{flex:0 0 257px;height:257px;max-height:257px;background:#e9e6e6;border-radius:4px;overflow:hidden;position:relative}
.gallery-map img{width:100%;height:100%;object-fit:cover;display:block}
.gallery-map #detail-map{position:absolute;inset:0;width:100%;height:100%}
.gallery-map .maplibregl-ctrl-attrib{font-size:9px}

/* ── META ROW ────────────────────────────────────── */
.meta-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:60px}
.meta-popular,.meta-save{display:flex;align-items:center;gap:7px;font-size:16px;color:#222;background:none;border:none;font-family:inherit;cursor:pointer;padding:0}
.meta-save.is-saved svg path{fill:var(--blue);stroke:var(--blue)}
.meta-popular strong{font-weight:600}
.meta-save{text-decoration:none;font-weight:500}

/* ── TITLE / DESCRIPTION ─────────────────────────── */
.title-row{display:flex;gap:88px;justify-content:space-between;align-items:flex-start;margin-bottom:40px}
.title-block{flex:1;max-width:800px}
.title-block h1{font-size:40px;font-weight:400;line-height:1.2;color:var(--text);margin:0 0 8px}
.title-block .address{font-size:18px;line-height:1;color:var(--text);margin:0 0 40px}
.title-block .description{font-size:16px;line-height:1.4;color:var(--text);margin:0}

/* ── CONTACT CARD ────────────────────────────────── */
.contact-card{flex:0 0 280px;background:var(--pink);color:#fff;border-radius:4px;padding:24px 24px 32px;display:flex;flex-direction:column;gap:24px}
.contact-card h3{font-size:22px;font-weight:500;line-height:1.4;margin:0 0 8px}
.contact-card > p{font-size:16px;line-height:1.2;margin:0}
.contact-btn{background:#fff;border:none;border-radius:30px;padding:14px 20px;display:flex;align-items:center;justify-content:center;gap:12px;font-family:inherit;font-size:16px;font-weight:500;color:var(--text);cursor:pointer;letter-spacing:-0.25px;width:100%}
.contact-btn:hover{background:#f5f5f5}

/* ── METRIC CARDS ────────────────────────────────── */
.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:16px}
.metric-card{background:#f6f6f6;border-radius:4px;padding:24px;height:170px;display:flex;flex-direction:column}
.metric-label{font-size:12px;font-weight:500;text-transform:uppercase;color:var(--text);letter-spacing:0.5px}
.metric-card{justify-content:space-between}
.metric-value{font-size:26px;color:var(--text);line-height:1.1;margin-top:auto}
.metric-sub{font-size:15px;color:var(--text);line-height:1;margin-top:4px}

/* ── DETAIL GRID ─────────────────────────────────── */
.detail-grid{display:flex;gap:16px;align-items:flex-start;margin-bottom:80px}
.detail-main{flex:1;display:flex;flex-direction:column;gap:16px;min-width:0}
.info-card{background:#f6f6f6;border-radius:4px;padding:24px 24px 32px}
.info-card h2{font-size:28px;font-weight:400;line-height:1.4;color:var(--text);margin:0 0 20px}

/* Materials */
.materials-intro{display:flex;gap:12px;align-items:flex-start;margin-bottom:32px}
.materials-intro svg{flex-shrink:0;margin-top:2px}
.materials-intro p{font-size:15px;line-height:1.3;color:var(--text);margin:0}
.material-group{margin-bottom:24px}
.material-group:last-child{margin-bottom:0}
.material-group h4{font-size:12px;font-weight:500;text-transform:uppercase;color:#6c6c6c;letter-spacing:0.5px;margin:0 0 12px}
.material-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.material-list li{display:flex;align-items:baseline;gap:8px;font-size:16px;color:var(--text)}
.m-name{flex:0 0 auto;line-height:1.4;white-space:nowrap}
.m-dots{flex:1;border-bottom:1px dotted #b9b7b8;align-self:center;min-width:30px}
.m-amt{flex:0 0 auto;font-size:15px;line-height:1.4;white-space:nowrap}
.m-tag{flex:0 0 80px;display:flex;align-items:center;justify-content:center;padding:6px;border-radius:4px;font-size:10px;font-weight:600;text-transform:uppercase;line-height:1;letter-spacing:0.3px}
.tag-verified{background:#00a36f;color:#fff}
.tag-screened{background:var(--blue);color:#fff}
.tag-unverified{background:#e1dfe0;color:var(--text)}

/* Timeline */
.timeline-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}
.timeline-list li{display:flex;align-items:center;gap:11px}
.t-dot{flex-shrink:0;width:20px;height:20px;border-radius:50%;background:#fff;border:2px solid #d7d5d6;box-sizing:border-box}
.t-dot.t-done{background:#00a36f;border-color:#00a36f;position:relative}
.t-dot.t-done::after{content:'';position:absolute;top:50%;left:50%;width:8px;height:5px;border-left:1.5px solid #fff;border-bottom:1.5px solid #fff;transform:translate(-50%,-65%) rotate(-45deg)}
.t-name{font-size:16px;line-height:1.4;color:var(--text);flex-shrink:0}
.t-dots{flex:1;border-bottom:1px dotted #b9b7b8;align-self:center;min-width:30px;margin:0 0 0 0}
.t-date{font-size:15px;line-height:1.4;color:var(--text);flex-shrink:0}

/* Stamdata */
.stamdata-card{flex:0 0 280px;background:#f6f6f6;border-radius:4px;padding:24px 24px 32px;align-self:stretch}
.stamdata-card h2{font-size:28px;font-weight:400;line-height:1.4;color:var(--text);margin:0 0 24px}
.stamdata-card dl{margin:0;display:flex;flex-direction:column;gap:25px}
.stamdata-card dt{font-size:10px;font-weight:500;text-transform:uppercase;color:#666;letter-spacing:0.5px;margin-bottom:4px}
.stamdata-card dd{font-size:16px;line-height:1.4;color:var(--text);margin:0}
.stamdata-card dd a{color:var(--text);text-decoration:underline;display:inline-flex;align-items:center;gap:8px}
.stamdata-card dd a .link-out{flex-shrink:0}
.stamdata-card dd + dd{margin-top:4px}

/* ── SIMILAR ─────────────────────────────────────── */
.similar{margin-bottom:80px}
.similar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:40px}
.similar-header h2{font-size:28px;font-weight:400;line-height:1.4;color:var(--text);margin:0}
.similar-nav{display:flex;gap:8px}
.nav-btn{width:44px;height:44px;background:#fff;border:1px solid #dcdcdc;border-radius:30px;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0}
.nav-btn-active{background:var(--pink);border-color:var(--pink)}
.nav-btn svg path{stroke:#222}
.nav-btn.nav-btn-active svg path{stroke:#fff}
.similar-carousel{overflow:hidden}
.similar-grid{display:flex;gap:24px;transition:transform 0.35s ease;will-change:transform}
.similar-card{flex:0 0 274px;display:flex;flex-direction:column;gap:24px;text-decoration:none;color:inherit}
.similar-img{height:150px;border-radius:4px;overflow:hidden;background:#e9e6e6}
.similar-img img{width:100%;height:100%;object-fit:cover;display:block}
.similar-card-body{display:flex;flex-direction:column;gap:16px}
.similar-card-info{display:flex;flex-direction:column;gap:8px}
.similar-card h3{font-size:18px;font-weight:500;line-height:1.4;color:var(--text);margin:0}
.similar-card p{font-size:16px;line-height:1.4;color:var(--text);margin:0}
.similar-link{display:inline-flex;align-items:center;gap:5px;font-size:16px;color:var(--pink);margin-top:0}

/* ── AGREEMENT ───────────────────────────────────── */
/* Frame 971:10040: bg #1f427d @7%, radius 4, min-h 500, pad 58/70; image (image 23) bleeds the right edge */
.agreement{position:relative;overflow:hidden;background:rgba(31,66,125,0.07);border-radius:4px;min-height:500px;padding:58px 70px;margin-bottom:100px}
.agreement-content{position:relative;z-index:1;max-width:520px}
.agreement-content h2{font-size:38px;font-weight:600;line-height:1.4;color:#222;margin:0 0 16px}
.agreement-content > p{font-size:18px;line-height:1.4;color:#222;margin:0 0 36px}
.agreement-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:20px}
.agreement-list li{display:flex;gap:14px;align-items:center}
.agreement-icon{flex-shrink:0;width:56px;height:56px;border-radius:50%;background:rgba(255,255,255,0.5);display:flex;align-items:center;justify-content:center}
.agreement-list a{display:inline-flex;align-items:center;gap:8px;color:var(--blue);font-size:16px;font-weight:600;text-decoration:underline}
.agreement-list a strong{font-weight:600}
.agreement-list p{font-size:16px;color:var(--blue);line-height:1.4;margin:4px 0 0}
.agreement-image{position:absolute;top:0;bottom:0;left:680px;right:0;width:auto;border-radius:0}
.agreement-image img{width:100%;height:100%;object-fit:cover;display:block}

/* ── FOOTER ──────────────────────────────────────── */
.footer{background:linear-gradient(120deg,#142546 0%,#1f427d 55%,#27518f 100%);color:#fff;padding:0}
.footer-inner{max-width:1168px;margin:0 auto;display:grid;grid-template-columns:234px 1fr 268px;column-gap:162px;padding:97px 0 0}
.footer-col h4{font-family:'Inter',sans-serif;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1px;opacity:0.7;margin:0 0 23px}
.footer-col h4.mt-32{margin-top:64px}
.footer-col p{font-size:15px;line-height:1.6;color:#fff;margin:0 0 12px}
.footer-col p a{color:#fff;text-decoration:underline}
.footer-brand .logo-name{color:#fff}
.footer-brand .logo-copy{color:#fff}
.footer-brand .logo{margin-top:-15px}
.footer-links{list-style:none;padding:0;margin:49px 0 0;display:flex;flex-direction:column;gap:12px}
.footer-links a{font-size:15px;color:#fff;text-decoration:none}
.footer-links a:hover{text-decoration:underline}
.footer-logos{display:flex;gap:16px;margin-top:12px}
.footer-logo{width:121px;height:55px;background:rgba(255,255,255,0.14);border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;letter-spacing:1px;color:#fff;opacity:0.9}
.footer-social{display:flex;gap:14px;margin-top:24px}
.footer-social a{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;transition:opacity 0.12s}
.footer-social a:hover{opacity:0.82}
.footer-social img{width:32px;height:32px;display:block}
.footer-bottom{margin:110px 0 0;padding:32px calc((100% - 1168px) / 2);display:flex;justify-content:space-between;font-size:14px;color:var(--text);background:#fff}
.footer-bottom a{color:var(--text);text-decoration:underline;margin:0 6px;opacity:0.8}

/* ── CONTACT MODAL ───────────────────────────────────────────────────────── */
.contact-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.82);display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;pointer-events:none;transition:opacity 220ms ease}
.contact-overlay.is-open{opacity:1;pointer-events:auto}
.contact-modal{width:789px;max-height:90vh;overflow-y:auto;background:#fff;border-radius:8px;box-shadow:0 10px 10px rgba(0,0,0,0.05);position:relative;transform:translateY(20px);opacity:0;transition:opacity 260ms ease 60ms,transform 260ms ease 60ms}
.contact-overlay.is-open .contact-modal{opacity:1;transform:translateY(0)}
.contact-modal-hd{padding:32px 40px 8px;position:relative}
.contact-modal-title{font-size:20px;font-weight:400;line-height:1;margin:0;color:#222}
.contact-modal-close{position:absolute;top:26px;right:18px;width:32px;height:32px;border:none;background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px;padding:0}
.contact-modal-close:hover{background:#f5f5f5}
.contact-modal-body{padding:32px 40px 36px;display:flex;flex-direction:column;gap:28px}
.contact-building{display:flex;height:188px}
.contact-bimg{width:269px;flex-shrink:0;background:#222;border-radius:1px;overflow:hidden}
.contact-bimg img{width:100%;height:100%;object-fit:cover;display:block}
.contact-binfo{flex:1;background:#eff2f6;border-radius:4px;padding:22px 24px;display:flex;flex-direction:column;gap:8px}
.contact-binfo strong{font-size:18px;font-weight:500;line-height:1.3;color:#222}
.contact-binfo p{font-size:16px;line-height:1.4;color:#222;margin:0}
.contact-person{display:flex;align-items:center;gap:16px}
.contact-avatar{width:53px;height:53px;border-radius:50%;background:var(--blue);color:#fff;font-size:16px;font-weight:600;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:inherit}
.contact-pname{font-size:20px;font-weight:600;color:#222;margin:0 0 5px}
.contact-prole{font-size:16px;color:var(--muted);margin:0}
.contact-rows{display:flex;flex-direction:column;border-top:1px solid #ebebeb;padding-left:16px}
.contact-row{display:flex;align-items:center;gap:8px;padding:15px 0;border-bottom:1px solid #ebebeb}
.contact-row:last-child{border-bottom:none}
.contact-row-lbl{font-size:16px;color:var(--muted);flex-shrink:0}
.contact-row-val{font-size:16px;color:#222;text-decoration:none;display:flex;align-items:center;gap:6px;margin-left:auto}
a.contact-row-val{color:var(--blue);text-decoration:underline}
a.contact-row-val:hover{opacity:0.8}
.contact-disclaimer{font-size:14px;line-height:1.5;color:#222;margin-top:-14px;background:#eff2f6;border-radius:4px;padding:14px 16px}

/* ── GALLERY LIGHTBOX ──────────────────────────────────────────── */
.gallery-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.82);display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;pointer-events:none;transition:opacity 220ms ease}
.gallery-overlay.is-open{opacity:1;pointer-events:auto}
/* Modal width = max that fits in 90vh with 16:9 viewer + 110px filmstrip, capped at 95vw */
.gallery-modal{width:min(95vw,calc((90vh - 110px) * 16 / 9));background:#fff;border-radius:8px;box-shadow:0 10px 40px rgba(0,0,0,0.25);position:relative;transform:translateY(20px);opacity:0;transition:opacity 260ms ease 60ms,transform 260ms ease 60ms;display:flex;flex-direction:column;overflow:hidden}
.gallery-overlay.is-open .gallery-modal{opacity:1;transform:translateY(0)}
.gallery-close-btn{position:absolute;top:20px;right:20px;height:32px;padding:0 12px;gap:6px;border:none;background:#222;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:16px;z-index:10;font-size:14px;font-family:inherit;color:#fff;transition:background 150ms ease}
.gallery-close-btn:hover{background:#333}
.gallery-close-btn span{position:relative;top:1px}
.gallery-close-btn svg path{stroke:#fff}
/* Viewer locked to 16:9 — prevents height-jump when switching images */
.glb-viewer{flex-shrink:0;width:100%;aspect-ratio:16/9;position:relative;background:#111;overflow:hidden}
.glb-img{width:100%;height:100%;object-fit:cover;display:block;transition:opacity 200ms ease}
.glb-img.fading{opacity:0}
.glb-nav{position:absolute;top:50%;transform:translateY(-50%);border:none;background:transparent;border-radius:50%;width:56px;height:56px;cursor:pointer;padding:0;z-index:5;display:flex;align-items:center;justify-content:center}
.glb-nav::before{content:'';position:absolute;inset:0;background:#fff;border-radius:50%;transition:transform 150ms ease;z-index:0}
.glb-nav img{position:relative;z-index:1;pointer-events:none}
.glb-nav:hover::before{transform:scale(1.1)}
.glb-prev{left:20px}
.glb-next{right:20px}
.glb-count{position:absolute;top:20px;left:20px;height:32px;display:flex;align-items:center;padding:0 12px;font-size:14px;font-family:inherit;line-height:1;color:#fff;background:#222;border-radius:16px}
.glb-filmstrip{padding:10px 20px;background:#fff;flex-shrink:0;display:flex;align-items:center;gap:16px}
.glb-filmstrip-inner{flex:1;min-width:0;display:flex;gap:10px;overflow-x:auto;position:relative;padding:4px;scrollbar-width:none;scroll-behavior:smooth}
.glb-filmstrip-inner::-webkit-scrollbar{display:none}
.glb-thumb{flex-shrink:0;width:130px;height:82px;border-radius:4px;overflow:hidden;cursor:pointer;opacity:0.55;transition:opacity 150ms ease}
.glb-thumb img{width:100%;height:100%;object-fit:cover;display:block;user-select:none;-webkit-user-drag:none}
.glb-thumb:hover{opacity:0.8}
.glb-thumb.active{opacity:1}
/* Frame: navy inner border — sits flush over active thumbnail */
.glb-filmstrip-frame{position:absolute;top:4px;left:4px;width:130px;height:82px;box-sizing:border-box;border:6px solid #1f427d;border-radius:4px;pointer-events:none;transition:transform 280ms ease-in-out;z-index:2}
