
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --ink:#0f1923;--ink2:#1e2d3d;--pine:#122a1e;
  --gold:#c9a84c;--gold-l:#e8c97a;
  --cream:#f7f4ee;--cream2:#ede8df;--mist:#eef1f6;--sky:#dce8f5;
  --blue:#2860c4;--blue2:#3d74d8;
  --red:#c0392b;--green:#1e7d47;--amber:#d97706;
  --slate:#5a6a7e;--border:#d8d2c8;--white:#fff;
  --sh:0 4px 24px rgba(15,25,35,.09);--sh-lg:0 12px 48px rgba(15,25,35,.18);
}
body{font-family:'Outfit',sans-serif;background:var(--cream);color:var(--ink);min-height:100vh}
h1,h2,h3,h4{font-family:'Playfair Display',serif}
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
@keyframes fu{from{opacity:0;transform:translateY(13px)}to{opacity:1;transform:translateY(0)}}
@keyframes fi{from{opacity:0}to{opacity:1}}
.fu{animation:fu .35s ease both}.fu1{animation:fu .35s .07s ease both}.fu2{animation:fu .35s .14s ease both}.fu3{animation:fu .35s .21s ease both}.fi{animation:fi .25s ease both}

/* ── HEADER ── */
.hdr{background:var(--ink);height:60px;display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;position:sticky;top:0;z-index:100;box-shadow:0 2px 20px rgba(0,0,0,.28)}
.brand{display:flex;align-items:center;gap:.7rem}
.bmark{width:38px;height:38px;border-radius:8px;overflow:hidden;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.bname{font-family:'Playfair Display',serif;font-size:1rem;color:#fff;letter-spacing:.01em}
.bsub{font-size:.67rem;color:rgba(255,255,255,.38);display:block;margin-top:-2px}
.hdr-r{display:flex;align-items:center;gap:.65rem}
.chip{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.75);font-size:.73rem;padding:.24rem .68rem;border-radius:20px}
.chip-gold{background:rgba(201,168,76,.14);border-color:rgba(201,168,76,.32);color:var(--gold)}
.ghost{background:none;border:1px solid rgba(255,255,255,.18);color:rgba(255,255,255,.58);padding:.26rem .68rem;border-radius:6px;cursor:pointer;font-size:.73rem;font-family:'Outfit',sans-serif;transition:.15s}
.ghost:hover{background:rgba(255,255,255,.08);color:#fff}

/* ── LOGIN ── */
.lscreen{min-height:calc(100vh - 60px);display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,var(--ink) 0%,var(--ink2) 50%,#0b2218 100%);position:relative;overflow:hidden;padding:2rem}
.lpat{position:absolute;inset:0;background-image:repeating-linear-gradient(45deg,rgba(201,168,76,.04) 0,rgba(201,168,76,.04) 1px,transparent 0,transparent 50%);background-size:30px 30px}
.lglow{position:absolute;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(201,168,76,.07) 0%,transparent 70%);pointer-events:none}
.lcard{background:#fff;border-radius:20px;width:100%;max-width:430px;box-shadow:var(--sh-lg);overflow:hidden;position:relative;z-index:1}
.ltop{background:var(--ink);padding:1.9rem;text-align:center;border-bottom:3px solid var(--gold)}
.llogo{width:72px;height:72px;border-radius:14px;overflow:hidden;margin:0 auto .7rem;display:flex;align-items:center;justify-content:center}
.ltop h2{color:#fff;font-size:1.2rem;margin-bottom:.22rem}
.ltop p{color:rgba(255,255,255,.38);font-size:.77rem}
.lbody{padding:1.6rem}
.field{margin-bottom:1.05rem}
.field label{display:block;font-size:.76rem;font-weight:500;color:var(--slate);margin-bottom:.32rem}
.field select,.field input{width:100%;border:1.5px solid var(--border);border-radius:9px;padding:.57rem .88rem;font-size:.87rem;font-family:'Outfit',sans-serif;background:var(--cream);color:var(--ink);transition:.18s;appearance:none}
.field select:focus,.field input:focus{outline:none;border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px rgba(40,96,196,.09)}
.fnote{font-size:.7rem;color:var(--slate);margin-top:.28rem}
.btn-l{width:100%;background:var(--ink);color:#fff;border:none;border-radius:9px;padding:.73rem;font-size:.92rem;font-weight:500;font-family:'Outfit',sans-serif;cursor:pointer;transition:.18s;margin-top:.2rem}
.btn-l:hover{background:var(--blue)}.btn-l:disabled{opacity:.55;cursor:not-allowed}
.err{color:var(--red);font-size:.76rem;margin-top:.42rem;text-align:center}
.llink{text-align:center;margin-top:1.1rem;font-size:.76rem;color:var(--slate)}
.lbtn{background:none;border:none;color:var(--blue);cursor:pointer;font-size:.76rem;text-decoration:underline;font-family:'Outfit',sans-serif}

/* ── APP SHELL ── */
.app{display:flex;min-height:calc(100vh - 60px)}
.sb{width:215px;min-width:215px;background:var(--ink2);padding:1.2rem 0;display:flex;flex-direction:column;gap:.08rem}
.sb-sec{font-size:.63rem;font-weight:600;letter-spacing:.13em;text-transform:uppercase;color:rgba(255,255,255,.23);padding:.5rem 1.1rem .28rem}
.nv{display:flex;align-items:center;gap:.62rem;padding:.56rem 1.1rem;cursor:pointer;font-size:.83rem;color:rgba(255,255,255,.48);border-left:3px solid transparent;transition:.14s}
.nv:hover{color:rgba(255,255,255,.82);background:rgba(255,255,255,.05)}
.nv.on{color:#fff;background:rgba(255,255,255,.08);border-left-color:var(--gold)}
.nv-ic{font-size:.9rem;width:17px;text-align:center;flex-shrink:0}
.nbadge{margin-left:auto;background:var(--red);color:#fff;font-size:.58rem;border-radius:10px;padding:.08rem .38rem;font-weight:600}
.main{flex:1;padding:1.7rem;overflow-y:auto;min-width:0}
.admin-bar{background:var(--pine);color:#fff;padding:.52rem 1.2rem;font-size:.76rem;display:flex;align-items:center;gap:.5rem;border-bottom:2px solid var(--gold)}

/* ── PAGE ── */
.pgh{margin-bottom:1.35rem}.pgh h2{font-size:1.28rem;color:var(--ink)}.pgh p{font-size:.8rem;color:var(--slate);margin-top:.18rem}
.card{background:#fff;border-radius:14px;border:1px solid var(--border);padding:1.2rem;margin-bottom:.95rem;box-shadow:var(--sh)}
.ctitle{font-family:'Playfair Display',serif;font-size:1rem;color:var(--ink);margin-bottom:.85rem;display:flex;align-items:center;gap:.48rem}
.ctitle-sm{font-weight:600;font-size:.82rem;color:var(--ink);margin-bottom:.65rem}

/* ── WELCOME BANNER ── */
.welcome-banner{
  background:linear-gradient(135deg,var(--ink) 0%,var(--ink2) 100%);
  border-radius:14px;padding:1.4rem 1.5rem;margin-bottom:.95rem;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  position:relative;overflow:hidden;
}
.welcome-banner::before{
  content:'';position:absolute;top:-30px;right:-30px;width:180px;height:180px;
  border-radius:50%;background:rgba(201,168,76,.08);
}
.wb-left{}
.wb-greeting{font-size:1.05rem;font-weight:600;color:#fff;margin-bottom:.2rem}
.wb-name{font-family:'Playfair Display',serif;font-size:1.55rem;color:var(--gold);margin-bottom:.3rem}
.wb-addr{font-size:.76rem;color:rgba(255,255,255,.45)}
.wb-meta{display:flex;flex-direction:column;align-items:flex-end;gap:.3rem}
.wb-badge{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);border-radius:8px;padding:.45rem .75rem;text-align:right}
.wb-badge-label{font-size:.65rem;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.08em}
.wb-badge-val{font-size:.85rem;color:#fff;font-weight:500}

/* ── METER TILES ── */
.mtiles{display:grid;grid-template-columns:repeat(3,1fr);gap:.85rem;margin-bottom:.95rem}
.mtile{background:var(--cream);border:1px solid var(--border);border-radius:12px;padding:.95rem 1.05rem;position:relative;overflow:hidden}
.mtile::before{content:'';position:absolute;top:0;left:0;right:0;height:3px}
.mtile.w::before{background:var(--blue)}.mtile.s::before{background:var(--gold)}.mtile.h::before{background:var(--red)}
.me{position:absolute;right:.78rem;top:.78rem;font-size:1.1rem;opacity:.2}
.ml{font-size:.67rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--slate);margin-bottom:.2rem}
.mv{font-size:1.45rem;font-weight:300;color:var(--ink);line-height:1}
.mu{font-size:.74rem;color:var(--slate);margin-left:.18rem}
.mdate{font-size:.67rem;color:var(--slate);margin-top:.25rem}
.mdelta{font-size:.69rem;margin-top:.16rem}
.du{color:var(--red)}.dd{color:var(--green)}
.mnum{font-size:.67rem;color:#a0b0c4;margin-top:.18rem;font-family:'Outfit',sans-serif}

/* ── SPARK ── */
svg.spark{width:100%;height:64px;overflow:visible}
.chart-lbl{font-size:.69rem;color:var(--slate);margin-top:.18rem}

/* ── QUICK ACTIONS ── */
.qa-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:.95rem}
.qa{background:#fff;border:1px solid var(--border);border-radius:12px;padding:1rem;text-align:center;cursor:pointer;transition:.15s;text-decoration:none}
.qa:hover{border-color:var(--blue);background:var(--sky)}
.qa-icon{font-size:1.5rem;margin-bottom:.4rem}
.qa-label{font-size:.78rem;font-weight:500;color:var(--ink)}
.qa-sub{font-size:.68rem;color:var(--slate);margin-top:.15rem}

/* ── NEWS ── */
.news-feed{display:flex;flex-direction:column;gap:.6rem}
.ni{display:flex;gap:.8rem;align-items:flex-start;background:var(--cream);border:1px solid var(--border);border-radius:10px;padding:.75rem .9rem;transition:.14s}
.ni:hover{background:var(--sky);border-color:#b8cfe8}
.ndot{width:32px;height:32px;border-radius:8px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:.9rem}
.di{background:#dce8f5}.dw{background:#e8d5f5}.da{background:#fef3cd}.dok{background:#d4edda}
.nbody{flex:1;min-width:0}
.ntitle{font-size:.85rem;font-weight:600;color:var(--ink);margin-bottom:.16rem}
.ntext{font-size:.77rem;color:var(--slate);line-height:1.43}
.nmeta{font-size:.67rem;color:#9aabb8;margin-top:.25rem}
.tag{display:inline-block;font-size:.62rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;border-radius:4px;padding:.09rem .4rem;margin-right:.28rem}
.tga{background:#dce8f5;color:var(--blue)}.tgw{background:#e8d5f5;color:#6a3e9e}.tgab{background:#fef3cd;color:#8a6000}.tgi{background:#d4edda;color:var(--green)}

/* ── DOCS ── */
.docg{display:flex;flex-direction:column;gap:.52rem}
.drow{display:flex;align-items:center;justify-content:space-between;background:var(--cream);border:1px solid var(--border);border-radius:9px;padding:.63rem .88rem;text-decoration:none;color:var(--ink);transition:.14s}
.drow:hover{background:var(--sky);border-color:#b8cfe8}
.dleft{display:flex;align-items:center;gap:.63rem}
.dname{font-size:.85rem;font-weight:500}.ddesc{font-size:.7rem;color:var(--slate)}
.doc-section-label{font-size:.68rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--slate);margin:.9rem 0 .4rem;padding-left:.1rem}
.doc-empty{font-size:.82rem;color:#b0bcc8;font-style:italic;padding:.5rem 0}
.upload-zone{border:2px dashed var(--border);border-radius:10px;padding:1.5rem;text-align:center;cursor:pointer;transition:.18s;background:var(--cream)}
.upload-zone:hover,.upload-zone.drag{border-color:var(--blue);background:var(--sky)}
.upload-zone input[type=file]{display:none}
.upload-icon{font-size:1.8rem;margin-bottom:.4rem}
.upload-label{font-size:.85rem;font-weight:500;color:var(--ink)}
.upload-sub{font-size:.72rem;color:var(--slate);margin-top:.2rem}
.upload-progress{height:4px;background:var(--border);border-radius:2px;margin-top:.75rem;overflow:hidden}
.upload-bar{height:100%;background:var(--blue);border-radius:2px;transition:width .3s}
.doc-admin-row{display:flex;align-items:center;gap:.65rem;background:var(--cream);border:1px solid var(--border);border-radius:9px;padding:.6rem .85rem;margin-bottom:.45rem}
.doc-admin-info{flex:1;min-width:0}
.doc-admin-name{font-size:.84rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.doc-admin-meta{font-size:.69rem;color:var(--slate);margin-top:.1rem}
.doc-cat-badge{font-size:.65rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;border-radius:4px;padding:.09rem .38rem;background:#dce8f5;color:var(--blue);white-space:nowrap;flex-shrink:0}
.doc-cat-badge.global{background:#d4edda;color:var(--green)}

/* ── CONTACT ── */
.il{display:flex;gap:.68rem;align-items:center;font-size:.84rem;margin-bottom:.52rem}
.il span:first-child{color:var(--slate);width:86px;font-size:.75rem;flex-shrink:0}
.btn-mail{display:inline-flex;align-items:center;gap:.5rem;background:var(--ink);color:#fff;border:none;border-radius:9px;padding:.68rem 1.4rem;font-size:.87rem;font-family:'Outfit',sans-serif;text-decoration:none;cursor:pointer;transition:.18s}
.btn-mail:hover{background:var(--blue)}

/* ── ADMIN ── */
.tabs-r{display:flex;gap:.42rem;margin-bottom:1.3rem;flex-wrap:wrap}
.tabbtn{padding:.36rem .92rem;border-radius:7px;border:1.5px solid var(--border);background:#fff;font-size:.78rem;cursor:pointer;color:var(--slate);font-family:'Outfit',sans-serif;transition:.14s}
.tabbtn.on{background:var(--ink);border-color:var(--ink);color:#fff}
.ugrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(95px,1fr));gap:.48rem;margin-bottom:1.15rem}
.upill{padding:.5rem;border:1.5px solid var(--border);border-radius:8px;background:#fff;text-align:center;cursor:pointer;font-size:.78rem;font-family:'Outfit',sans-serif;color:var(--slate);transition:.14s}
.upill:hover{border-color:var(--blue);color:var(--blue)}.upill.sel{background:var(--ink);border-color:var(--ink);color:#fff}
.irow{display:grid;gap:.78rem;margin-bottom:.82rem}
.ig{display:flex;flex-direction:column;gap:.26rem}
.ig label{font-size:.72rem;font-weight:500;color:var(--slate)}
.ig input,.ig select,.ig textarea{border:1.5px solid var(--border);border-radius:8px;padding:.46rem .76rem;font-size:.86rem;font-family:'Outfit',sans-serif;color:var(--ink);background:var(--cream);transition:.14s;width:100%}
.ig input:focus,.ig select:focus,.ig textarea:focus{outline:none;border-color:var(--blue);background:#fff}
.ig textarea{resize:vertical;min-height:76px}
.bsave{background:var(--green);color:#fff;border:none;border-radius:8px;padding:.56rem 1.45rem;font-size:.83rem;font-family:'Outfit',sans-serif;cursor:pointer;transition:.14s}
.bsave:hover{opacity:.87}
.bdel{background:var(--red);color:#fff;border:none;border-radius:6px;padding:.3rem .65rem;font-size:.76rem;font-family:'Outfit',sans-serif;cursor:pointer}
.bsm{background:var(--ink);color:#fff;border:none;border-radius:6px;padding:.3rem .68rem;font-size:.73rem;font-family:'Outfit',sans-serif;cursor:pointer}
.mok{color:var(--green);font-size:.77rem;margin-left:.62rem}
.merr{color:var(--red);font-size:.77rem;margin-left:.62rem}
.dtbl{width:100%;border-collapse:collapse;font-size:.8rem}
.dtbl th{background:var(--cream);padding:.46rem .68rem;text-align:left;color:var(--slate);font-weight:500;border-bottom:1px solid var(--border)}
.dtbl td{padding:.46rem .68rem;border-bottom:1px solid var(--border)}
.dtbl tr:last-child td{border-bottom:none}.dtbl tr:hover td{background:var(--cream)}
.ttgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:.82rem}
.tt{background:#fff;border:1px solid var(--border);border-radius:12px;padding:.95rem;transition:.14s}
.tt:hover{border-color:var(--blue);box-shadow:0 4px 14px rgba(40,96,196,.1)}
.ttloc{font-size:.66rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--slate);margin-bottom:.2rem}
.ttunit{font-size:.95rem;font-weight:600;color:var(--ink);margin-bottom:.15rem}
.tttenant{font-size:.78rem;color:var(--blue);margin-bottom:.4rem;font-weight:500}
.ttm{font-size:.72rem;color:var(--slate);display:flex;gap:.36rem;margin-bottom:.13rem}
.ttm span:first-child{width:52px}
.ttnone{font-size:.75rem;color:#b0bcc8;font-style:italic}
.pw-row{display:grid;grid-template-columns:160px 100px 1fr 88px;gap:.62rem;align-items:center;padding:.42rem 0;border-bottom:1px solid var(--border)}
.pw-row:last-child{border-bottom:none}
.pwh{font-size:.69rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--slate)}
.pwtag{background:var(--cream2);border-radius:5px;padding:.2rem .52rem;font-size:.72rem;font-weight:600}
.pwinp{border:1.5px solid var(--border);border-radius:7px;padding:.36rem .63rem;font-size:.82rem;font-family:'Outfit',sans-serif;color:var(--ink);background:var(--cream);width:100%}
.pwinp:focus{outline:none;border-color:var(--blue);background:#fff}
.naitem{display:flex;gap:.8rem;align-items:flex-start;background:var(--cream);border:1px solid var(--border);border-radius:9px;padding:.75rem .9rem;margin-bottom:.52rem}
.sec-divider{border:none;border-top:1px solid var(--border);margin:.95rem 0}
.info-box{background:var(--mist);border:1px solid #c5d5e8;border-radius:9px;padding:.75rem 1rem;font-size:.78rem;color:var(--blue);margin-bottom:.85rem}
@media(max-width:680px){
  .sb{display:none}
  .mtiles{grid-template-columns:1fr}
  .qa-grid{grid-template-columns:1fr 1fr}
  .irow{grid-template-columns:1fr!important}
  .pw-row{grid-template-columns:1fr 1fr}
  .main{padding:1rem;padding-bottom:80px}
  .inp-row{grid-template-columns:1fr 1fr!important}
}
.mob-nav{display:none}
@media(max-width:680px){
  .mob-nav{
    display:flex;position:fixed;bottom:0;left:0;right:0;
    background:var(--ink2);border-top:1px solid rgba(255,255,255,.1);
    z-index:99;height:62px;
  }
  .mob-nav-item{
    flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
    gap:.18rem;cursor:pointer;transition:.14s;color:rgba(255,255,255,.45);
    font-size:.6rem;font-weight:500;border:none;background:none;
    position:relative;
  }
  .mob-nav-item.on{color:var(--gold)}
  .mob-nav-item .mn-icon{font-size:1.25rem;line-height:1}
  /* ── READ BUTTON ── */
.news-read-btn{background:none;border:1px solid var(--border);color:var(--slate);border-radius:6px;padding:.2rem .55rem;font-size:.68rem;font-family:'Outfit',sans-serif;cursor:pointer;flex-shrink:0;transition:.15s;margin-left:.5rem}
.news-read-btn:hover{background:var(--green);border-color:var(--green);color:#fff}
.news-read-btn.done{background:#d4edda;border-color:#b8dfc7;color:var(--green);cursor:default}

/* ── CHAT ── */
.chat-wrap{display:flex;flex-direction:column;height:calc(100vh - 220px);min-height:300px}
.chat-msgs{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.55rem;padding:.25rem 0 1rem}
.chat-msg{display:flex;flex-direction:column;max-width:82%}
.chat-msg.mine{align-self:flex-end;align-items:flex-end}
.chat-msg.theirs{align-self:flex-start;align-items:flex-start}
.chat-bubble{padding:.55rem .85rem;border-radius:12px;font-size:.85rem;line-height:1.42;word-break:break-word}
.chat-msg.mine .chat-bubble{background:var(--blue);color:#fff;border-bottom-right-radius:3px}
.chat-msg.theirs .chat-bubble{background:var(--cream2);color:var(--ink);border-bottom-left-radius:3px}
.chat-time{font-size:.66rem;color:var(--slate);margin-top:.18rem;padding:0 .25rem}
.chat-sender{font-size:.68rem;font-weight:600;color:var(--slate);margin-bottom:.15rem;padding:0 .25rem}
.chat-input-row{display:flex;gap:.65rem;align-items:flex-end;padding-top:.75rem;border-top:1px solid var(--border);margin-top:.5rem}
.chat-input{flex:1;border:1.5px solid var(--border);border-radius:10px;padding:.55rem .9rem;font-size:.88rem;font-family:'Outfit',sans-serif;resize:none;min-height:42px;max-height:110px;background:var(--cream);color:var(--ink);transition:.15s}
.chat-input:focus{outline:none;border-color:var(--blue);background:#fff}
.chat-send{background:var(--blue);color:#fff;border:none;border-radius:9px;padding:.55rem 1.1rem;font-size:.88rem;font-family:'Outfit',sans-serif;cursor:pointer;transition:.15s;flex-shrink:0}
.chat-send:hover{background:var(--blue2)}.chat-send:disabled{opacity:.5;cursor:not-allowed}
.chat-empty{color:var(--slate);font-size:.83rem;text-align:center;padding:2rem 0;font-style:italic}
.chat-unread-dot{width:8px;height:8px;background:var(--red);border-radius:50%;display:inline-block;margin-left:.4rem;vertical-align:middle}
/* Admin chat list */
.chat-unit-row{display:flex;align-items:center;justify-content:space-between;background:var(--cream);border:1px solid var(--border);border-radius:9px;padding:.65rem .9rem;cursor:pointer;transition:.15s;margin-bottom:.5rem}
.chat-unit-row:hover{background:var(--sky);border-color:#b8cfe8}
.chat-unit-row.active{background:var(--sky);border-color:var(--blue)}
.chat-unit-name{font-size:.87rem;font-weight:600;color:var(--ink)}
.chat-unit-meta{font-size:.72rem;color:var(--slate);margin-top:.1rem}
.chat-unread-badge{background:var(--red);color:#fff;font-size:.65rem;border-radius:10px;padding:.1rem .4rem;font-weight:700}

.mob-nav-badge{
    position:absolute;top:6px;right:calc(50% - 16px);
    background:var(--red);color:#fff;font-size:.55rem;
    border-radius:8px;padding:.05rem .3rem;font-weight:700;
  }
}
