/* ================================================
   BRICS REAL ESTATE — CLIENT PORTAL v4
   Light · Airy · Professional
   ================================================ */

:root {
  --black:   #0D0D0D;
  --dark:    #1A1A1A;
  --text:    #1A1A1A;
  --text2:   #4A4A4A;
  --text3:   #9A9A9A;
  --border:  #EBEBEB;
  --bg:      #F7F7F7;
  --bg2:     #F0F0F0;
  --white:   #FFFFFF;
  --bronze:  #B8924A;
  --bronze2: #9A7A38;
  --ok:      #2A6644;
  --warn:    #8A5A00;
  --err:     #8A2020;
  --info:    #1A5080;
  --ok-bg:   rgba(42,102,68,.06);
  --warn-bg: rgba(138,90,0,.06);
  --err-bg:  rgba(138,32,32,.06);
  --info-bg: rgba(26,80,128,.06);
  --serif:   'Cormorant Garamond', Georgia, serif;
  --sans:    'Montserrat', sans-serif;
  --sh:      0 1px 3px rgba(0,0,0,.04), 0 4px 12px rgba(0,0,0,.04);
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { font-size:14px; }
body { font-family:var(--sans); background:var(--bg); color:var(--text); height:100vh; height:100dvh; overflow:hidden; box-sizing:border-box; }
::-webkit-scrollbar { width:4px; }
::-webkit-scrollbar-thumb { background:var(--border); }
a { text-decoration:none; color:inherit; }
input, select, textarea, button { font-family:var(--sans); }

.view { display:none; width:100%; height:100vh; height:100dvh; flex-direction:column; }
.view.on { display:flex; }

/* ================================================
   LOGIN
   ================================================ */
#login { flex-direction:row; }

.ll {
  width:50%;
  background:var(--black);
  display:flex; flex-direction:column; justify-content:space-between;
  padding:52px 56px;
  position:relative; overflow:hidden;
}
.ll::after {
  content:''; position:absolute;
  bottom:-100px; right:-100px;
  width:360px; height:360px;
  border-radius:50%;
  border:1px solid rgba(184,146,74,.1);
  pointer-events:none;
}

.ll-logo { display:flex; align-items:center; gap:12px; margin-bottom:68px; }
.ll-logo-name { font-family:var(--serif); font-size:16px; font-weight:500; color:#fff; letter-spacing:3px; text-transform:uppercase; }
.ll-logo-name b { color:var(--bronze); font-weight:500; }
.ll-logo-sub { font-size:8px; color:rgba(255,255,255,.22); letter-spacing:3px; text-transform:uppercase; margin-top:2px; }

.ll-head h1 { font-family:var(--serif); font-size:52px; font-weight:300; color:#fff; line-height:1.12; }
.ll-head h1 i { color:var(--bronze); font-style:italic; }
.ll-head p { font-size:11.5px; color:rgba(255,255,255,.36); margin-top:20px; line-height:1.9; font-weight:300; max-width:340px; }

.ll-flags { display:flex; gap:7px; flex-wrap:wrap; margin-bottom:24px; }
.ll-flag { padding:4px 12px; border:1px solid rgba(255,255,255,.09); font-size:9.5px; color:rgba(255,255,255,.3); font-weight:500; letter-spacing:.5px; }

.ll-stats { display:flex; gap:36px; padding-top:22px; border-top:1px solid rgba(255,255,255,.07); }
.ls-val { font-family:var(--serif); font-size:28px; color:#fff; }
.ls-lbl { font-size:9px; color:rgba(255,255,255,.25); text-transform:uppercase; letter-spacing:1px; margin-top:3px; }

.lr-wrap { width:50%; background:var(--white); display:flex; align-items:center; justify-content:center; padding:52px; }
.lf { width:100%; max-width:330px; }
.lf-title { font-family:var(--serif); font-size:36px; font-weight:400; color:var(--dark); margin-bottom:5px; }
.lf-sub { font-size:11px; color:var(--text3); margin-bottom:34px; }

.fg { margin-bottom:14px; }
.fg label { display:block; font-size:9px; font-weight:700; text-transform:uppercase; letter-spacing:1.2px; color:var(--text3); margin-bottom:6px; }
.fi { width:100%; padding:11px 13px; background:var(--bg); border:1px solid var(--border); font-size:13px; color:var(--text); outline:none; transition:border .2s; }
.fi:focus { background:#fff; border-color:var(--dark); }
.fi::placeholder { color:var(--text3); }

.lf-forgot { text-align:right; margin:-6px 0 20px; }
.lf-forgot a { font-size:10px; color:var(--text3); transition:color .2s; }
.lf-forgot a:hover { color:var(--bronze); }

.btn-login { width:100%; padding:13px; background:var(--dark); color:#fff; border:none; cursor:pointer; font-size:10.5px; font-weight:700; letter-spacing:2px; text-transform:uppercase; transition:background .2s; }
.btn-login:hover { background:var(--black); }

.lf-or { display:flex; align-items:center; gap:14px; margin:20px 0; font-size:10px; color:var(--text3); }
.lf-or::before, .lf-or::after { content:''; flex:1; height:1px; background:var(--border); }

.demo-grid { display:grid; grid-template-columns:1fr 1fr; gap:7px; }
.dbtn { padding:9px 8px; background:#fff; border:1px solid var(--border); cursor:pointer; font-size:10px; font-weight:600; color:var(--text2); text-align:center; transition:all .2s; }
.dbtn:hover { border-color:var(--dark); color:var(--dark); background:var(--bg); }
.dbtn-icon { display:block; margin-bottom:4px; }
.dbtn-icon svg { stroke:var(--text3); }

.lf-back { text-align:center; margin-top:20px; font-size:10px; color:var(--text3); }
.lf-back a { color:var(--text3); transition:color .2s; }
.lf-back a:hover { color:var(--bronze); }

/* ================================================
   PORTAL SHELL
   ================================================ */
#portal { flex-direction:column; }

/* Top Nav */
.pnav {
  background:var(--white);
  border-bottom:1px solid var(--border);
  display:flex; align-items:center;
  flex-shrink:0; z-index:100;
  position:relative;
  /* Safe area: pushes nav BELOW Dynamic Island / notch */
  padding-top: env(safe-area-inset-top);
  padding-left: max(24px, env(safe-area-inset-left));
  padding-right: max(24px, env(safe-area-inset-right));
  padding-bottom: 0;
  /* Height grows with safe area */
  min-height: calc(58px + env(safe-area-inset-top));
}

.p-logo { display:flex; align-items:center; gap:10px; }
.p-logo-name { font-family:var(--serif); font-size:15px; font-weight:500; color:var(--dark); letter-spacing:2.5px; text-transform:uppercase; }
.p-logo-name b { color:var(--bronze); font-weight:500; }
.p-logo-sub { font-size:7px; color:var(--text3); letter-spacing:2px; text-transform:uppercase; margin-top:2px; }
.p-logo-div { width:1px; height:28px; background:var(--border); margin:0 16px; }

.pnav-links { display:flex; }
.pnav-link { padding:0 14px; height:58px; display:flex; align-items:center; font-size:10.5px; font-weight:600; letter-spacing:.6px; text-transform:uppercase; color:var(--text2); cursor:pointer; border-bottom:2px solid transparent; transition:all .2s; white-space:nowrap; }
.pnav-link:hover { color:var(--text); }
.pnav-link.on { color:var(--dark); border-bottom-color:var(--bronze); }

.pnav-right { display:flex; align-items:center; gap:8px; margin-left:20px; }

.lang-wrap { position:relative; }
.lang-btn { display:flex; align-items:center; gap:5px; padding:6px 10px; background:transparent; border:1px solid var(--border); color:var(--text3); font-size:10px; font-weight:600; cursor:pointer; transition:all .2s; }
.lang-btn:hover { border-color:var(--dark); color:var(--dark); }
.lang-dd { position:absolute; top:calc(100% + 4px); right:0; background:var(--white); border:1px solid var(--border); min-width:148px; z-index:300; display:none; box-shadow:var(--sh); }
.lang-dd.on { display:block; }
.lang-opt { padding:8px 13px; font-size:11px; color:var(--text2); cursor:pointer; transition:background .15s; }
.lang-opt:hover { background:var(--bg); }
.lang-opt.sel { color:var(--bronze); font-weight:600; }

.pnav-icon { width:32px; height:32px; background:transparent; border:1px solid var(--border); display:flex; align-items:center; justify-content:center; cursor:pointer; transition:all .2s; position:relative; }
.pnav-icon:hover { border-color:var(--dark); }
.pnav-icon svg { stroke:var(--text3); }
.notif-dot { position:absolute; top:5px; right:5px; width:6px; height:6px; background:var(--bronze); border-radius:50%; border:1.5px solid var(--white); }

.pnav-user { display:flex; align-items:center; gap:8px; padding:5px 10px 5px 5px; border:1px solid var(--border); cursor:pointer; transition:all .2s; }
.pnav-user:hover { background:var(--bg); }
.pnav-av { width:27px; height:27px; background:linear-gradient(135deg,#8A6B2C,var(--bronze)); display:flex; align-items:center; justify-content:center; font-family:var(--serif); font-size:12px; color:#fff; font-weight:600; }
.pnav-name { font-size:11px; font-weight:600; color:var(--dark); }
.pnav-role { font-size:9px; color:var(--text3); text-transform:uppercase; letter-spacing:.4px; }

.pnav-cta { padding:8px 16px; background:var(--dark); color:#fff; border:none; cursor:pointer; font-size:9.5px; font-weight:700; letter-spacing:1px; text-transform:uppercase; transition:background .2s; white-space:nowrap; }
.pnav-cta:hover { background:var(--black); }

/* Body */
.pbody { flex:1; display:flex; overflow:hidden; }

/* ================================================
   SIDEBAR — light, slim, clean
   ================================================ */
.sb {
  width:210px; min-width:210px;
  background:var(--white);
  border-right:1px solid var(--border);
  display:flex; flex-direction:column;
  overflow-y:auto;
}

.sb-role-wrap { padding:14px 12px; border-bottom:1px solid var(--border); }
.sb-rlbl { font-size:8px; font-weight:700; text-transform:uppercase; letter-spacing:1.5px; color:var(--text3); margin-bottom:8px; }
.sb-rg { display:grid; grid-template-columns:1fr 1fr 1fr; gap:3px; margin-bottom:3px; }
.sb-rg2 { display:grid; grid-template-columns:1fr 1fr; gap:3px; }
.sb-rb { padding:5px 4px; background:transparent; border:1px solid var(--border); font-size:9px; font-weight:600; text-transform:uppercase; color:var(--text3); cursor:pointer; transition:all .18s; text-align:center; }
.sb-rb:hover { border-color:var(--dark); color:var(--dark); }
.sb-rb.on { background:var(--dark); border-color:var(--dark); color:#fff; }

.sb-nav { flex:1; padding:8px 0; }
.sb-gl { padding:14px 14px 4px; font-size:8px; font-weight:700; text-transform:uppercase; letter-spacing:1.8px; color:var(--border); }
.sb-item {
  display:flex; align-items:center; gap:9px;
  padding:11px 14px;
  font-size:11.5px; font-weight:500;
  color:var(--text3);
  cursor:pointer; transition:all .15s;
  width:100%; text-align:left;
  background:transparent; border:none;
  touch-action:manipulation;
  -webkit-tap-highlight-color:transparent;
  font-family:var(--sans);
  min-height:44px;
}
.sb-item svg { stroke:var(--border); flex-shrink:0; transition:stroke .15s; }
.sb-item:hover { color:var(--text); background:var(--bg); }
.sb-item:hover svg { stroke:var(--text3); }
.sb-item.on {
  color:var(--dark); font-weight:600;
  background:var(--bg);
}
.sb-item.on svg { stroke:var(--bronze); }
.sb-item.on::before { content:''; display:block; width:3px; height:100%; background:var(--bronze); position:absolute; left:0; }
.sb-item { position:relative; }

.sb-badge { margin-left:auto; padding:1px 6px; font-size:8.5px; font-weight:700; border-radius:10px; }
.br { background:var(--err-bg); color:var(--err); }
.bb { background:var(--info-bg); color:var(--info); }
.bo { background:var(--warn-bg); color:var(--warn); }

.sb-foot { padding:10px 12px; border-top:1px solid var(--border); }
.sb-fbtn { display:flex; align-items:center; gap:8px; padding:7px 0; font-size:11px; color:var(--text3); cursor:pointer; transition:color .2s; }
.sb-fbtn svg { stroke:var(--border); transition:stroke .2s; }
.sb-fbtn:hover { color:var(--err); }
.sb-fbtn:hover svg { stroke:var(--err); }

/* Main content */
.mc { flex:1; overflow-y:auto; background:var(--bg); min-width:0; width:100%; }

/* Footer */
.pf { min-height:46px; padding-bottom:max(env(safe-area-inset-bottom), 0px); background:var(--white); border-top:1px solid var(--border); display:flex; align-items:stretch; flex-shrink:0; }
.pf-btn { flex:1; display:flex; align-items:center; justify-content:center; gap:7px; color:var(--text3); font-size:9.5px; font-weight:600; letter-spacing:.8px; text-transform:uppercase; border-right:1px solid var(--border); transition:all .2s; }
.pf-btn:last-child { border-right:none; }
.pf-btn:hover { background:var(--bg); color:var(--dark); }
.pf-btn svg { stroke:var(--text3); transition:stroke .2s; }
.pf-btn:hover svg { stroke:var(--dark); }

/* ================================================
   CONTENT COMPONENTS
   ================================================ */

/* Page header */
.ph { padding:28px 28px 0; display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:24px; }
.ph-title { font-family:var(--serif); font-size:28px; font-weight:300; color:var(--dark); }
.ph-sub { font-size:11px; color:var(--text3); margin-top:3px; }
.ph-acts { display:flex; gap:8px; align-items:center; flex-shrink:0; }

/* Buttons */
.btn { padding:8px 18px; border:none; cursor:pointer; font-size:10px; font-weight:700; letter-spacing:1px; text-transform:uppercase; transition:all .2s; display:inline-flex; align-items:center; gap:6px; }
.btn svg { stroke:currentColor; }
.btn-dark { background:var(--dark); color:#fff; }
.btn-dark:hover { background:var(--black); }
.btn-ghost { background:transparent; color:var(--text2); border:1px solid var(--border); }
.btn-ghost:hover { border-color:var(--dark); color:var(--dark); }
.btn-bronze { background:var(--bronze); color:#fff; }
.btn-bronze:hover { background:var(--bronze2); }
.btn-danger { background:transparent; color:var(--err); border:1px solid rgba(138,32,32,.18); }
.btn-danger:hover { background:var(--err-bg); }
.btn-ok { background:transparent; color:var(--ok); border:1px solid rgba(42,102,68,.22); }
.btn-ok:hover { background:var(--ok-bg); }
.bsm { padding:7px 13px; font-size:9.5px; }
.bxs { padding:4px 10px; font-size:9px; }

/* Stats */
.stats { display:grid; gap:1px; background:var(--border); }
.s4 { grid-template-columns:repeat(4,1fr); }
.s3 { grid-template-columns:repeat(3,1fr); }
.sc { background:var(--white); padding:20px 22px; }
.sc-icon { margin-bottom:10px; }
.sc-icon svg { stroke:var(--border); }
.sc-val { font-family:var(--serif); font-size:26px; font-weight:500; color:var(--dark); line-height:1; }
.sc-lbl { font-size:9px; font-weight:600; color:var(--text3); text-transform:uppercase; letter-spacing:.8px; margin-top:5px; }
.sc-d { font-size:10px; margin-top:6px; }
.up { color:var(--ok); }
.dn { color:var(--err); }
.nt { color:var(--text3); }

/* Grids */
.g2 { display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--border); }
.g3 { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }

/* White panel */
.pw { background:var(--white); padding:22px; }
.pw-np { background:var(--white); }
.pht { display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; }
.pt { font-family:var(--serif); font-size:18px; font-weight:400; color:var(--dark); }

/* Section divider */
.sdiv { height:1px; background:var(--border); margin:16px 0; }

/* KPI strip */
.kpi-row { display:flex; background:var(--border); gap:1px; }
.kpi { flex:1; background:var(--white); padding:16px 20px; }
.kv { font-family:var(--serif); font-size:22px; color:var(--bronze); }
.kl { font-size:9px; color:var(--text3); text-transform:uppercase; letter-spacing:.8px; margin-top:4px; font-weight:600; }

/* Chips */
.chip { display:inline-flex; align-items:center; padding:2px 8px; font-size:9px; font-weight:700; letter-spacing:.4px; text-transform:uppercase; white-space:nowrap; border-radius:2px; }
.cg { background:var(--ok-bg); color:var(--ok); }
.ca { background:var(--warn-bg); color:var(--warn); }
.cr { background:var(--err-bg); color:var(--err); }
.cb { background:var(--info-bg); color:var(--info); }
.co { background:rgba(184,146,74,.08); color:var(--bronze); }
.cx { background:var(--bg); color:var(--text3); }

/* List rows */
.lr { display:flex; align-items:center; gap:12px; padding:11px 0; border-bottom:1px solid var(--bg2); cursor:pointer; transition:background .15s; }
.lr:last-child { border-bottom:none; }
.lr:hover { background:var(--bg); margin:0 -22px; padding:11px 22px; }
.lr-icon { width:34px; height:34px; flex-shrink:0; background:var(--bg); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; }
.lr-icon svg { stroke:var(--text3); }
.lr-t { font-size:12.5px; font-weight:600; color:var(--dark); }
.lr-s { font-size:10.5px; color:var(--text3); margin-top:2px; }
.lr-r { margin-left:auto; text-align:right; flex-shrink:0; }
.lr-v { font-family:var(--serif); font-size:15px; color:var(--bronze); }
.lr-m { font-size:10px; color:var(--text3); margin-top:2px; }

/* Ticket rows */
.tr { padding:11px 0; border-bottom:1px solid var(--bg2); cursor:pointer; border-left:2px solid transparent; padding-left:10px; transition:background .15s; }
.tr:last-child { border-bottom:none; }
.tr:hover { background:var(--bg); }
.tr-h { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:4px; }
.tr-t { font-size:12.5px; font-weight:600; color:var(--dark); }
.tr-m { display:flex; gap:10px; font-size:10px; color:var(--text3); flex-wrap:wrap; }
.t-u { border-left-color:var(--err); }
.t-m { border-left-color:var(--warn); }
.t-l { border-left-color:var(--ok); }

/* Message rows */
.mr { display:flex; gap:11px; padding:11px 0; border-bottom:1px solid var(--bg2); cursor:pointer; transition:background .15s; }
.mr:last-child { border-bottom:none; }
.mr:hover { background:var(--bg); }
.mr.unread { background:#FEFCF8; }
.m-av { width:32px; height:32px; flex-shrink:0; background:var(--bg); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; font-family:var(--serif); font-size:13px; color:var(--text3); font-weight:600; }
.m-n { font-size:12px; font-weight:600; color:var(--dark); }
.m-p { font-size:10.5px; color:var(--text3); margin-top:2px; max-width:200px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.m-t { margin-left:auto; font-size:10px; color:var(--text3); flex-shrink:0; }
.m-dot { width:6px; height:6px; background:var(--bronze); border-radius:50%; margin-top:5px; }

/* Table */
.tbl { width:100%; border-collapse:collapse; }
.tbl th { text-align:left; padding:0 0 9px; font-size:9px; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:var(--text3); border-bottom:1px solid var(--border); }
.tbl td { padding:10px 0; font-size:12px; color:var(--text); border-bottom:1px solid var(--bg2); vertical-align:middle; }
.tbl tr:last-child td { border-bottom:none; }
.tbl tr:hover td { background:var(--bg); }
.tbl th:not(:first-child), .tbl td:not(:first-child) { padding-left:14px; }
.tv { font-family:var(--serif); font-size:14px; color:var(--bronze); }

/* Progress */
.prog { height:2px; background:var(--bg2); border-radius:1px; }
.progf { height:100%; background:var(--bronze); border-radius:1px; transition:width .4s; }

/* Steps */
.steps { display:flex; padding:6px 0 14px; }
.step { flex:1; text-align:center; position:relative; }
.step::after { content:''; position:absolute; top:10px; left:50%; right:-50%; height:1px; background:var(--border); z-index:0; }
.step:last-child::after { display:none; }
.sdot { width:20px; height:20px; background:var(--bg); border:1.5px solid var(--border); display:flex; align-items:center; justify-content:center; margin:0 auto 5px; font-size:9px; font-weight:700; position:relative; z-index:1; }
.sdot.done { background:var(--ok); border-color:var(--ok); color:#fff; }
.sdot.curr { background:var(--dark); border-color:var(--dark); color:#fff; }
.slbl { font-size:8.5px; color:var(--text3); font-weight:600; text-transform:uppercase; }
.step.done .slbl { color:var(--ok); }
.step.curr .slbl { color:var(--dark); }

/* Timeline */
.tl { position:relative; padding-left:18px; }
.tl::before { content:''; position:absolute; left:6px; top:0; bottom:0; width:1px; background:var(--border); }
.tl-i { position:relative; margin-bottom:16px; }
.tl-d { position:absolute; left:-13px; top:3px; width:8px; height:8px; border-radius:50%; border:2px solid var(--white); }
.tl-db { background:var(--bronze); }
.tl-dg { background:var(--ok); }
.tl-t { font-size:12.5px; font-weight:600; color:var(--dark); }
.tl-s { font-size:10.5px; color:var(--text3); margin-top:2px; line-height:1.5; }

/* Form */
.fg2 { margin-bottom:13px; }
.fg2 label { display:block; font-size:9px; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:var(--text3); margin-bottom:5px; }
.fi2 { width:100%; padding:9px 12px; background:var(--bg); border:1px solid var(--border); font-size:12.5px; color:var(--text); outline:none; transition:all .2s; }
.fi2:focus { background:#fff; border-color:var(--dark); }
textarea.fi2 { resize:vertical; min-height:70px; }
.fr { display:grid; gap:11px; margin-bottom:13px; }
.fr2 { grid-template-columns:1fr 1fr; }

/* Upload */
.upload-z { border:1.5px dashed var(--border); padding:22px; text-align:center; cursor:pointer; transition:all .2s; background:var(--bg); }
.upload-z:hover { border-color:var(--bronze); }
.upload-z svg { stroke:var(--text3); margin-bottom:7px; }
.upload-z p { font-size:11.5px; color:var(--text3); }
.upload-z span { color:var(--bronze); font-weight:600; }

/* Checklist */
.cl-list { list-style:none; }
.cl-i { display:flex; align-items:center; gap:10px; padding:8px 0; border-bottom:1px solid var(--bg2); cursor:pointer; font-size:12px; }
.cl-i:last-child { border-bottom:none; }
.cl-b { width:15px; height:15px; flex-shrink:0; border:1.5px solid var(--border); display:flex; align-items:center; justify-content:center; transition:all .2s; }
.cl-b.on { background:var(--ok); border-color:var(--ok); }
.cl-b.on svg { stroke:#fff; }
.cl-done { text-decoration:line-through; color:var(--text3); }

/* Approval card */
.approvc { border-left:3px solid var(--warn); background:var(--white); padding:16px 18px; margin-bottom:2px; }
.approvc-top { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:7px; }
.approvc-title { font-size:13.5px; font-weight:600; color:var(--dark); }
.approvc-sub { font-size:10.5px; color:var(--text3); margin-top:2px; }
.approvc-amt { font-family:var(--serif); font-size:20px; color:var(--bronze); flex-shrink:0; margin-left:12px; }
.approvc-d { font-size:11px; color:var(--text3); margin-bottom:13px; line-height:1.6; }
.approvc-act { display:flex; gap:7px; }

/* Property card */
.prop-card { background:var(--white); cursor:pointer; transition:all .2s; overflow:hidden; border:1px solid var(--border); }
.prop-card:hover { box-shadow:0 4px 20px rgba(0,0,0,.07); transform:translateY(-2px); }
.prop-img { height:148px; background:var(--bg2); position:relative; display:flex; align-items:center; justify-content:center; }
.prop-img svg { stroke:var(--border); opacity:.6; }
.prop-ov { position:absolute; inset:0; background:linear-gradient(to top,rgba(0,0,0,.4) 0%,transparent 60%); }
.prop-fl { position:absolute; top:10px; left:10px; background:var(--black); color:#fff; font-size:9px; font-weight:700; letter-spacing:1px; padding:3px 8px; text-transform:uppercase; }
.prop-tp { position:absolute; top:10px; right:10px; background:var(--bronze); color:#fff; font-size:9px; font-weight:700; letter-spacing:1px; padding:3px 8px; text-transform:uppercase; }
.prop-b { padding:14px; }
.prop-p { font-family:var(--serif); font-size:19px; color:var(--dark); margin-bottom:3px; }
.prop-n { font-size:12.5px; font-weight:600; color:var(--dark); margin-bottom:3px; }
.prop-l { font-size:10.5px; color:var(--text3); margin-bottom:10px; }
.prop-sp { display:flex; gap:12px; padding-top:9px; border-top:1px solid var(--bg2); }
.prop-s { font-size:10px; color:var(--text3); }
.prop-s strong { color:var(--text); font-weight:600; }

/* Vendor card */
.vcard { background:var(--white); padding:16px; border:1px solid var(--border); transition:all .2s; cursor:pointer; }
.vcard:hover { border-color:var(--text3); box-shadow:var(--sh); }
.vc-h { display:flex; align-items:center; gap:9px; margin-bottom:11px; }
.vc-av { width:34px; height:34px; background:var(--bg); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; }
.vc-av svg { stroke:var(--text3); }
.vc-n { font-size:12.5px; font-weight:700; color:var(--dark); }
.vc-t { font-size:10px; color:var(--text3); }
.vc-s { display:flex; gap:14px; padding-top:9px; border-top:1px solid var(--bg2); }
.vc-sv { font-family:var(--serif); font-size:16px; color:var(--bronze); }
.vc-sl { font-size:9px; color:var(--text3); text-transform:uppercase; letter-spacing:.4px; }

/* Deal pipeline */
.pipe { display:flex; gap:12px; overflow-x:auto; padding:0 28px 28px; }
.pc { min-width:200px; }
.pc-h { padding:9px 12px; margin-bottom:7px; background:var(--bg); display:flex; justify-content:space-between; align-items:center; border:1px solid var(--border); }
.pc-ht { font-size:10px; font-weight:700; color:var(--dark); text-transform:uppercase; letter-spacing:.8px; }
.p-card { background:var(--white); padding:12px; border:1px solid var(--border); margin-bottom:7px; cursor:pointer; transition:all .2s; }
.p-card:hover { border-color:var(--text3); }
.p-ct { font-size:12px; font-weight:600; color:var(--dark); margin-bottom:4px; }
.p-cv { font-family:var(--serif); font-size:15px; color:var(--bronze); }
.p-cm { font-size:10px; color:var(--text3); margin-top:4px; }

/* Map */
.map-b { background:var(--bg2); position:relative; overflow:hidden; display:flex; align-items:center; justify-content:center; border:1px solid var(--border); }
.map-b::before { content:''; position:absolute; inset:0; background:repeating-linear-gradient(0deg,transparent,transparent 32px,rgba(0,0,0,.02) 32px,rgba(0,0,0,.02) 33px),repeating-linear-gradient(90deg,transparent,transparent 32px,rgba(0,0,0,.02) 32px,rgba(0,0,0,.02) 33px); }
.map-lbl { position:absolute; top:12px; left:12px; background:var(--dark); color:#fff; font-size:9px; font-weight:700; letter-spacing:1px; padding:3px 10px; text-transform:uppercase; }
.map-pins { position:relative; z-index:1; display:flex; gap:32px; align-items:flex-end; }
.map-pin { display:flex; flex-direction:column; align-items:center; gap:4px; cursor:pointer; transition:transform .2s; }
.map-pin:hover { transform:translateY(-4px); }
.map-pin-ico { font-size:22px; filter:drop-shadow(0 2px 4px rgba(0,0,0,.15)); }
.map-pin-lbl { background:var(--white); color:var(--dark); font-size:9px; font-weight:700; padding:3px 8px; box-shadow:var(--sh); border:1px solid var(--border); white-space:nowrap; }

/* Chart */
.cbars { display:flex; align-items:flex-end; gap:4px; height:80px; }
.cbar { flex:1; background:var(--bg2); border-top:2px solid var(--border); cursor:pointer; transition:all .2s; }
.cbar:hover { background:rgba(184,146,74,.1); border-top-color:var(--bronze); }
.cbar.hi { background:rgba(184,146,74,.08); border-top-color:var(--bronze); }
.clbls { display:flex; gap:4px; padding-top:5px; }
.clbls span { flex:1; font-size:8.5px; color:var(--text3); text-align:center; font-weight:500; }

/* Access code */
.access-box { background:var(--dark); padding:28px; text-align:center; max-width:340px; margin:0 auto; }
.ac-lbl { font-size:9px; color:rgba(255,255,255,.3); letter-spacing:1.5px; text-transform:uppercase; margin-bottom:12px; }
.ac-code { font-family:var(--serif); font-size:44px; letter-spacing:12px; color:var(--bronze); }
.ac-t { font-size:11px; color:rgba(255,255,255,.3); margin-top:10px; }
.ac-w { font-size:10.5px; color:rgba(138,90,0,.8); margin-top:6px; }

/* ROI */
.calc-res { background:var(--dark); padding:20px; text-align:center; margin-top:12px; }
.calc-main { font-family:var(--serif); font-size:38px; color:#fff; }
.calc-sub { font-size:9px; color:rgba(255,255,255,.3); letter-spacing:1px; margin-top:3px; text-transform:uppercase; }
.calc-g { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-top:12px; padding-top:12px; border-top:1px solid rgba(255,255,255,.07); }
.calc-gv { font-family:var(--serif); font-size:17px; color:var(--bronze); }
.calc-gl { font-size:9px; color:rgba(255,255,255,.3); text-transform:uppercase; letter-spacing:.8px; margin-top:2px; }

/* Doc row */
.doc-r { display:flex; align-items:center; gap:11px; padding:10px 0; border-bottom:1px solid var(--bg2); cursor:pointer; transition:background .15s; }
.doc-r:last-child { border-bottom:none; }
.doc-r:hover { background:var(--bg); }
.doc-r svg { stroke:var(--text3); flex-shrink:0; }
.doc-n { font-size:12.5px; font-weight:600; color:var(--dark); }
.doc-i { font-size:10px; color:var(--text3); margin-top:2px; }
.doc-ri { margin-left:auto; display:flex; align-items:center; gap:7px; }

/* Page animation */
.cp { display:none; }
.cp.on { display:block; animation:fu .18s ease; }
/* ================================================
   iOS / SAFARI FIXES
   ================================================ */
* { -webkit-tap-highlight-color: transparent; }
button, [onclick], .sb-item, .pnav-link, .pf-btn, .btn {
  cursor: pointer;
  touch-action: manipulation;
  -webkit-user-select: none;
  user-select: none;
}
input, textarea, select { -webkit-user-select: text; user-select: text; }
/* Prevent bounce scroll on iOS */
.mc { -webkit-overflow-scrolling: touch; overscroll-behavior: contain; }
.sb { -webkit-overflow-scrolling: touch; }

/* ================================================
   ICONS
   ================================================ */
@keyframes fu { from { opacity:0; transform:translateY(3px); } to { opacity:1; transform:translateY(0); } }

/* ================================================
   MOBILE RESPONSIVE
   ================================================ */

/* Hamburger button */
.hamburger {
  display: none;
  flex-direction: column;
  gap: 4px;
  cursor: pointer;
  padding: 6px;
  margin-right: 10px;
  background: transparent;
  border: none;
  width: 44px;
  height: 44px;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 110;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}
.hamburger span {
  display: block;
  width: 20px;
  height: 2px;
  background: var(--dark);
  transition: all .25s;
}
.hamburger.open span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity: 0; }
.hamburger.open span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

/* Sidebar overlay on mobile */
.sb-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.35);
  z-index: 199;
  -webkit-tap-highlight-color: transparent;
}
.sb-overlay.on { display: block; }

@media (max-width: 768px) {

  /* Nav */
  .pnav { 
    padding-top: max(14px, env(safe-area-inset-top));
    padding-left: max(14px, env(safe-area-inset-left));
    padding-right: max(14px, env(safe-area-inset-right));
    padding-bottom: 0;
    min-height: calc(54px + env(safe-area-inset-top));
    height: auto;
  }
  .hamburger { display: flex; }
  .pnav-links { display: none; }

  /* Sidebar shows on mobile via hamburger — re-enable flex when needed */
  .sb { display: flex; transform: translateX(-100%); transition: transform .25s ease; }
  .p-logo-div { display: none; }
  .p-logo-sub { display: none; }
  .p-logo-name { font-size: 13px; letter-spacing: 2px; }
  .pnav-name, .pnav-role { display: none; }
  .pnav-user { border: none; padding: 4px; }
  .pnav-cta { display: none; }
  .lang-btn { font-size: 9px; padding: 5px 8px; }

  /* Sidebar — slides in from left */
  .sb {
    position: fixed;
    top: calc(54px + env(safe-area-inset-top));
    padding-left: env(safe-area-inset-left);
    padding-bottom: env(safe-area-inset-bottom);
    left: 0;
    bottom: 0;
    width: 240px;
    z-index: 200;
    transform: translateX(-100%);
    transition: transform .25s ease;
    box-shadow: 4px 0 20px rgba(0,0,0,.1);
  }
  .sb.open { transform: translateX(0); }

  /* Body — full width on mobile */
  .pbody { flex-direction: column; }
  .mc { flex: 1; width: 100%; }

  /* Page header */
  .ph { padding: 18px 16px 0; margin-bottom: 16px; flex-wrap: wrap; gap: 10px; }
  .ph-title { font-size: 22px; }
  .ph-acts { flex-wrap: wrap; }

  /* Stats — 2 columns on mobile */
  .stats.s4 { grid-template-columns: 1fr 1fr; }
  .stats.s3 { grid-template-columns: 1fr 1fr; }
  .sc { padding: 16px; }
  .sc-val { font-size: 22px; }

  /* KPI strip — 2 columns */
  .kpi-row { flex-wrap: wrap; }
  .kpi { min-width: 50%; border-bottom: 1px solid var(--border); }

  /* 2-col grids → 1-col */
  .g2 { grid-template-columns: 1fr; }

  /* 3-col grids → 1-col */
  .g3 { grid-template-columns: 1fr; }

  /* Panels */
  .pw { padding: 16px; }
  .pipe { padding: 0 16px 20px; }

  /* Property cards */
  .prop-img { height: 130px; }

  /* Deal pipeline — horizontal scroll */
  .pipe { gap: 10px; }
  .pc { min-width: 180px; }

  /* Login — stack vertically */
  #login { flex-direction: column; overflow-y: auto; height: auto; min-height: 100vh; }
  .ll { width: 100%; padding: 36px 28px 32px; min-height: auto; }
  .ll::after { display: none; }
  .ll-head h1 { font-size: 36px; }
  .ll-head p { display: none; }
  .ll-logo { margin-bottom: 32px; }
  .ll-stats { gap: 24px; }
  .lr-wrap { width: 100%; padding: 32px 28px 40px; }

  /* Footer */
  .pf { height: 52px; }
  .pf-btn { font-size: 8.5px; gap: 5px; flex-direction: column; }
  .pf-btn svg { width: 13px; height: 13px; }

  /* Buttons — full width in forms */
  .fr2 { grid-template-columns: 1fr; }

  /* Table — horizontal scroll */
  .tbl-wrap { overflow-x: auto; }
  .tbl { min-width: 480px; }

  /* Access code */
  .access-box { max-width: 100%; }
  .ac-code { font-size: 34px; letter-spacing: 8px; }

  /* ROI calc */
  .calc-main { font-size: 30px; }

  /* Touch targets — min 44px for Apple/Android guidelines */
  .btn { min-height: 44px; padding: 0 16px; }
  .bsm { min-height: 40px; }
  .sb-item { padding: 13px 14px; }
  .pnav-icon { width: 40px; height: 40px; }
  .pnav-user { padding: 8px 12px 8px 8px; }
  .fi2, input.fi2, select.fi2, textarea.fi2 { font-size: 16px; } /* prevent zoom on iOS */

  /* Stack page header buttons vertically on very small screens */
  .ph { gap: 12px; }
  .ph-acts .btn + .btn { margin-top: 0; }
}

@media (max-width: 420px) {
  .stats.s4 { grid-template-columns: 1fr 1fr; }
  .demo-grid { grid-template-columns: 1fr 1fr; }
  .ph-title { font-size: 20px; }
  .ll-head h1 { font-size: 30px; }
  .ll { padding: 28px 20px 24px; }
  .lr-wrap { padding: 24px 20px 32px; }
  .ll-flags { display: none; }
}
