*,*::before,*::after{border-radius:0 !important}   /* flat: no rounded corners anywhere */
:root{
  --ink:#1a1d21; --ink-2:#2b2f33; --line:#e3e6ea; --bg:#f5f6f8;
  --accent:#1c6cb4; --accent-d:#155693; --white:#fff; --muted:#6b7178;
  --p-shingle:#b0573a; --p-slate:#3f5566; --p-cedar-shingle:#c08a3e;
  --p-cedar-shake:#6e4a2a; --p-tile:#e0822e; --p-standing-seam:#2e7d8f;
  --hdr:56px; --panel:312px; --list:360px;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--bg)}
body{display:flex;flex-direction:column;height:100vh;overflow:hidden}

.topbar{height:var(--hdr);flex:0 0 var(--hdr);background:linear-gradient(135deg,#2a2f3d,#1f2330 55%,#181b25);color:#fff;display:flex;align-items:center;gap:16px;padding:0 18px;z-index:30;box-shadow:0 1px 0 rgba(0,0,0,.25)}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none;color:inherit}
.brand .logo{height:30px;width:auto;display:block}
.brand .divider{width:1px;height:22px;background:rgba(255,255,255,.22)}
.wordmark{font-weight:800;letter-spacing:.16em;font-size:18px}
.sub{color:#aab2bd;font-weight:600;font-size:12px;letter-spacing:.14em;text-transform:uppercase}
.tagline{flex:1;min-width:0;margin:0;text-align:center;font-size:12.5px;color:#c8ccd1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 14px}
.tagline .t1,.tagline #liveCount{display:inline}
.tagline #liveCount{font-weight:400;color:#aab2bd}
.topnav{margin-left:auto;display:flex;gap:16px;font-size:13.5px;font-weight:500}
.topnav a{color:#fff;text-decoration:none}
.topnav a:hover{color:#05ADED}
.panel-toggle{display:none;margin-left:auto;background:var(--accent);color:#fff;border:0;border-radius:6px;padding:8px 12px;font-weight:600;cursor:pointer}

.layout{flex:1;display:flex;min-height:0}
.panel{flex:0 0 var(--panel);width:var(--panel);background:#fff;border-right:1px solid var(--line);overflow:hidden;z-index:20}
.panel-scroll{height:100%;overflow-y:auto;padding:16px 16px 22px}
.panel-head{display:flex;align-items:center;justify-content:space-between;margin:0 0 14px}
.panel-title{font-size:16px;font-weight:800;letter-spacing:.01em}
.clearall{background:none;border:0;color:var(--accent-d);font-size:13px;font-weight:600;cursor:pointer;padding:2px 0}
.clearall:hover{text-decoration:underline}
.field{position:relative}
.field-ic{position:absolute;left:11px;top:50%;transform:translateY(-50%);width:17px;height:17px;fill:var(--muted);pointer-events:none}
.field input{width:100%;padding:10px 12px 10px 34px;border:1px solid var(--line);border-radius:9px;font-size:14px;background:#fff}
.field input:focus{outline:none;border-color:#05ADED}
.facet{border-top:1px solid var(--line)}
.facet-h{width:100%;display:flex;align-items:center;justify-content:space-between;background:none;border:0;padding:14px 0 12px;font-size:14px;font-weight:700;color:var(--ink);cursor:pointer;text-align:left;font-family:inherit}
.facet-h .chev{width:8px;height:8px;border-right:2px solid var(--muted);border-bottom:2px solid var(--muted);transform:rotate(45deg);transition:transform .15s;margin:0 2px 3px 0;flex:0 0 auto}
.facet.closed .chev{transform:rotate(-45deg)}
.facet-body{padding-bottom:14px}
.facet.closed .facet-body{display:none}
.opts{display:flex;flex-direction:column;gap:7px}
.opts.row{flex-direction:row;gap:8px}
.opts.scroll{max-height:188px;overflow-y:auto;padding-right:4px}
label.opt{display:flex;align-items:center;gap:9px;font-size:14px;cursor:pointer;user-select:none}
label.opt input{accent-color:var(--accent);margin:0}
.opt .sw{width:12px;height:12px;border-radius:3px;flex:0 0 12px}
.opt .cnt{margin-left:auto;color:var(--muted);font-size:12px;font-variant-numeric:tabular-nums}
.opt.pill{border:1px solid var(--line);border-radius:20px;padding:6px 12px;flex:1;justify-content:center}
.opt.pill input{display:none}
.opt.pill.on{background:var(--ink);color:#fff;border-color:var(--ink)}

.yearwrap{position:relative}
.yearwrap input[type=range]{width:100%}
.yearlabel{display:flex;justify-content:space-between;font-size:12px;color:var(--muted);margin-top:4px;font-variant-numeric:tabular-nums}
.note{margin-top:16px;font-size:11.5px;line-height:1.5;color:var(--muted)}
.note a{color:#05ADED;text-decoration:underline}
.note a:hover{color:#0497cf}

.mapwrap{position:relative;flex:1;min-width:0}
#map{position:absolute;inset:0}
.legend{position:absolute;left:12px;bottom:12px;background:rgba(255,255,255,.94);border:1px solid var(--line);border-radius:8px;padding:9px 11px;font-size:12px;display:flex;flex-wrap:wrap;gap:8px 14px;max-width:60%;box-shadow:0 2px 8px rgba(0,0,0,.08)}
.legend .li{display:flex;align-items:center;gap:6px;background:none;border:0;font:inherit;color:inherit;cursor:pointer;padding:3px 6px;margin:-3px -2px;border-radius:6px;transition:opacity .12s,background .12s}
.legend .li:hover{background:rgba(0,0,0,.06)}
.legend .li.on{background:rgba(0,0,0,.09);font-weight:700}
.legend.filtering .li:not(.on){opacity:.42}
.legend .sw{width:10px;height:10px;border-radius:3px;flex:0 0 auto}
#reloadNotice{position:absolute;inset:0;z-index:9;display:flex;align-items:center;justify-content:center;pointer-events:none}
#reloadNotice .rn-box{pointer-events:auto;background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px 20px;text-align:center;box-shadow:0 6px 24px rgba(0,0,0,.16)}
#reloadNotice p{margin:0 0 11px;font-size:13.5px;color:var(--ink-2)}
#reloadNotice .rn-btn{background:#05ADED;color:#fff;border:0;border-radius:8px;padding:9px 16px;font-size:13px;font-weight:600;cursor:pointer}
#reloadNotice .rn-btn:hover{background:#048fc4}

.seo-summary{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0)}

.maplibregl-popup-content{font-family:inherit;border-radius:10px;padding:12px 14px;box-shadow:0 6px 24px rgba(0,0,0,.18)}
.pop h4{margin:0 0 4px;font-size:14px}
.pop .chip{display:inline-block;font-size:11px;padding:2px 8px;border-radius:20px;color:#fff;margin-bottom:6px}
.pop .meta{font-size:12.5px;color:var(--ink-2);line-height:1.5}
.pop .anon{font-size:11px;color:var(--muted);margin-top:6px}

.modeswitch{position:absolute;top:12px;left:12px;z-index:6;display:flex;background:#fff;border:1px solid var(--line);border-radius:9px;overflow:hidden;box-shadow:0 2px 10px rgba(0,0,0,.12)}
.modebtn{border:0;background:#fff;padding:8px 15px;font-size:13px;font-weight:600;color:var(--ink-2);cursor:pointer}
.modebtn+.modebtn{border-left:1px solid var(--line)}
.modebtn.on{background:var(--ink);color:#fff}

/* ---- collapsible project list pane (RealWork-style) ---- */
.listpane{flex:0 0 var(--list);width:var(--list);background:#fff;border-right:1px solid var(--line);display:flex;flex-direction:column;min-height:0;transition:margin-left .22s ease}
.layout.list-collapsed .listpane{margin-left:calc(-1 * var(--list))}
.listhead{flex:0 0 auto;display:flex;align-items:center;gap:6px;padding:11px 14px;border-bottom:1px solid var(--line);font-size:13px;color:var(--muted)}
.listhead .lcount{font-weight:800;color:var(--ink)}
.listhead .lcollapse{margin-left:auto;background:#fff;border:1px solid var(--line);border-radius:7px;width:28px;height:28px;cursor:pointer;color:var(--ink-2);font-size:16px;line-height:1}
.listhead .lcollapse:hover{border-color:#05ADED;color:#05ADED}
.listscroll{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:12px}
.pcard{flex:0 0 auto;border:1px solid var(--line);border-radius:12px;overflow:hidden;cursor:pointer;background:#fff;transition:box-shadow .15s,border-color .15s}
.pcard:hover{border-color:#05ADED;box-shadow:0 6px 20px rgba(0,0,0,.10)}
.pcard .thumb{position:relative;height:150px;background:#eceef1}
.pcard .thumb img{width:100%;height:100%;object-fit:cover;display:block}
.pcard .badge{position:absolute;top:8px;left:8px;background:rgba(31,35,48,.92);color:#fff;font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:3px 8px;border-radius:20px}
.pcard .body{padding:10px 12px}
.pcard .ttl{font-weight:700;font-size:13.5px;line-height:1.3}
.pcard .tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:7px}
.pcard .tg{font-size:11px;background:#f0f2f4;border-radius:20px;padding:2px 9px;color:var(--ink-2)}
.pcard .rev{margin-top:8px;font-size:12.5px;color:var(--muted);line-height:1.4}
.pcard .rev .st{color:#e0a826;letter-spacing:1px}
.listopen{display:none;position:absolute;top:12px;left:12px;z-index:7;background:#fff;border:1px solid var(--line);border-radius:9px;padding:8px 15px;font-weight:600;font-size:13px;color:var(--ink-2);cursor:pointer;box-shadow:0 2px 10px rgba(0,0,0,.12)}
.listopen:hover{color:#05ADED;border-color:#05ADED}
.layout.list-collapsed .listopen{display:block}
.layout.list-collapsed .modeswitch{left:172px}

/* ---- detail modal ---- */
.modal{position:fixed;inset:0;z-index:100;background:rgba(20,22,30,.55);display:flex;align-items:center;justify-content:center;padding:24px 16px}
.modal[hidden]{display:none}
.modal-box{background:#fff;border-radius:16px;max-width:960px;width:100%;max-height:92vh;display:flex;flex-direction:column;box-shadow:0 30px 80px rgba(0,0,0,.45);overflow:hidden}
.modal-top{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;padding:13px 20px;border-bottom:1px solid var(--line)}
.modal-top .mlogo{height:22px}
.modal-x{background:#f0f2f4;border:0;width:34px;height:34px;border-radius:50%;font-size:19px;cursor:pointer;color:var(--ink-2)}
.modal-x:hover{background:#e3e6ea}
.modal-body{flex:1 1 auto;overflow-y:auto;padding:18px 22px 24px}
.mgallery img,.mgallery .mgmore{cursor:zoom-in}
.mgmore{position:absolute;right:8px;bottom:8px;background:rgba(31,35,48,.92);color:#fff;border:0;border-radius:20px;padding:6px 12px;font-size:12px;font-weight:600;cursor:pointer}
.mgallery{position:relative}
.modal-foot{flex:0 0 auto;display:flex;align-items:center;gap:8px;padding:11px 16px;border-top:1px solid var(--line);background:#fff;flex-wrap:wrap}
.modal-foot .mf{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:var(--ink-2);text-decoration:none;background:#f4f6f8;border:1px solid var(--line);border-radius:8px;padding:8px 13px;cursor:pointer}
.modal-foot .mf:hover{border-color:#05ADED;color:#05ADED}
.modal-foot .mf .mi{font-size:14px}
.modal-foot .cta{margin-left:auto;background:#05ADED;color:#fff;border-color:#05ADED}
.modal-foot .cta:hover{background:#048fc4;color:#fff;border-color:#048fc4}
@media(max-width:680px){.modal-foot .mf .mt{display:none}.modal-foot .cta .mt,.modal-foot .cta{display:inline}.modal-foot{gap:6px}}

.lightbox{position:fixed;inset:0;z-index:200;background:rgba(8,9,12,.92);display:flex;align-items:center;justify-content:center}
.lightbox[hidden]{display:none}
.lightbox img{max-width:92vw;max-height:88vh;border-radius:8px;box-shadow:0 10px 50px rgba(0,0,0,.6)}
.lb-x{position:absolute;top:18px;right:22px;background:rgba(255,255,255,.12);color:#fff;border:0;width:42px;height:42px;border-radius:50%;font-size:24px;cursor:pointer}
.lb-x:hover{background:rgba(255,255,255,.22)}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.12);color:#fff;border:0;width:50px;height:50px;border-radius:50%;font-size:30px;line-height:1;cursor:pointer}
.lb-nav:hover{background:rgba(255,255,255,.22)}
.lb-prev{left:20px}.lb-next{right:20px}
.lb-cap{position:absolute;bottom:18px;left:0;right:0;text-align:center;color:#cfd3da;font-size:13px;font-variant-numeric:tabular-nums}
@media(max-width:680px){.lb-nav{width:40px;height:40px;font-size:24px}.lb-prev{left:8px}.lb-next{right:8px}}
.modal-body h2{margin:0 0 14px;font-size:23px;line-height:1.25;border:0;padding:0}
.mgallery{display:grid;grid-template-columns:2fr 1fr;grid-auto-rows:1fr;gap:10px;margin-bottom:16px;max-height:340px}
.mgallery .hero{grid-row:1/3;border-radius:12px;overflow:hidden;background:#eceef1}
.mgallery .side{border-radius:12px;overflow:hidden;background:#eceef1}
.mgallery img{width:100%;height:100%;object-fit:cover;display:block}
.mcols{display:grid;grid-template-columns:1.6fr 1fr;gap:24px}
.mtags{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:12px}
.mtags .tg{font-size:12px;background:#f0f2f4;border-radius:20px;padding:3px 11px;color:var(--ink-2)}
.mdesc{font-size:14px;line-height:1.6;color:var(--ink-2);margin-top:14px}
.mcap{font-size:14.5px;line-height:1.5;color:var(--ink);margin:0 0 14px;font-weight:500}
.mspec{margin:0}
.mspec>div{display:grid;grid-template-columns:118px 1fr;gap:12px;padding:8px 0;border-bottom:1px solid var(--line)}
.mspec>div:first-child{border-top:1px solid var(--line)}
.mspec dt{margin:0;font-size:11px;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);font-weight:700}
.mspec dd{margin:0;font-size:13.5px;line-height:1.4;color:var(--ink)}
.mreview{margin-top:16px;border:1px solid var(--line);border-radius:12px;padding:14px}
.mreview .st{color:#e0a826;font-size:15px;letter-spacing:1px}
.mreview p{margin:8px 0;font-size:13.5px;line-height:1.55;color:var(--ink-2)}
.mreview .who{font-size:12.5px;color:var(--muted)}
.revsrc{display:inline-flex;align-items:center;margin-top:9px;text-decoration:none;font-size:12px;color:#1c6cb4}
.revsrc:hover{text-decoration:underline}
.gqlogo{height:20px;width:auto;display:block}
.glogo{height:18px;width:auto;display:block}
.pop .revsrc{margin-top:0}
.msimilar h3{font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:0 0 10px}
.msim{display:flex;gap:10px;align-items:center;border:1px solid var(--line);border-radius:10px;padding:7px;margin-bottom:10px;cursor:pointer}
.msim:hover{border-color:#05ADED}
.msim img{width:58px;height:46px;object-fit:cover;border-radius:7px;background:#eceef1;flex:0 0 auto}
.msim .t{font-size:12.5px;font-weight:600;line-height:1.3}
@media(max-width:900px){.mcols{grid-template-columns:1fr}.mgallery{grid-template-columns:1fr;max-height:none}.mgallery .hero{grid-row:auto}.mgallery .side{height:150px}}

@media(max-width:760px){
  .listpane{display:none}
  .tagline{display:none}
  .topnav{display:none}
  .panel-toggle{display:block}
  .panel{position:absolute;top:var(--hdr);bottom:0;left:0;transform:translateX(-100%);transition:transform .2s;box-shadow:2px 0 16px rgba(0,0,0,.18)}
  .panel.open{transform:none}
  .legend{max-width:80%}
}

/* a11y: skip link, hidden labels, focus, reduced motion */
.skip-link{position:absolute;left:8px;top:-48px;z-index:2147483600;background:#0d2233;color:#fff;padding:10px 14px;border-radius:8px;text-decoration:none}
.skip-link:focus{top:8px}
.visually-hidden{position:absolute!important;width:1px;height:1px;margin:-1px;padding:0;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
:focus-visible{outline:3px solid #1b72e7;outline-offset:2px}
@media (prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}}
