
:root{
  --blue:#145fe2;--blue2:#0b2a63;--gold:#d7a64a;--ink:#101827;--muted:#667085;
  --bg:#edf5ff;--card:#ffffff;--line:#e4e9f2;--green:#1f8a4c;--danger:#b42318;
  --shadow:0 16px 40px rgba(15,44,91,.12);--radius:22px;
}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Arial,Helvetica,sans-serif;background:linear-gradient(180deg,#f6fbff 0%,#ecf5ff 55%,#f8fbff 100%);color:var(--ink);font-size:15.5px;overflow-x:hidden}body:before{content:"";position:fixed;inset:0;background:radial-gradient(circle at 15% 10%,rgba(215,166,74,.13),transparent 28%),radial-gradient(circle at 85% 5%,rgba(20,95,226,.12),transparent 30%);pointer-events:none;z-index:-2}body:after{content:"";position:fixed;right:-80px;bottom:-80px;width:330px;height:330px;background:url('../img/building-blur.webp') center/cover no-repeat;border-radius:50%;opacity:.12;filter:blur(1px);pointer-events:none;z-index:-1}a{color:var(--blue);text-decoration:none}.topbar{position:sticky;top:0;z-index:30;background:rgba(255,255,255,.88);backdrop-filter:blur(16px);border-bottom:1px solid rgba(226,232,240,.9);display:flex;align-items:center;justify-content:space-between;padding:9px 16px}.brand{display:flex;gap:10px;align-items:center;color:var(--ink);min-width:0}.brand img{width:74px;max-height:50px;object-fit:contain;background:transparent!important;filter:drop-shadow(0 8px 14px rgba(11,42,99,.12))}.brand b{display:block;color:var(--blue2);font-size:18px;line-height:1.1;white-space:nowrap}.brand span span{display:block;font-size:12px;color:#64748b;line-height:1.15}.topbar>a{color:#475467;font-weight:700;font-size:14px}.wrap{padding:16px 14px 94px;max-width:1180px;margin:auto}h1{font-size:28px;line-height:1.1;margin:18px 0 12px;color:#0f172a;letter-spacing:-.02em}h2{font-size:21px;margin:6px 0 16px;color:#101828}.card{background:rgba(255,255,255,.92);border:1px solid rgba(228,233,242,.9);border-radius:var(--radius);padding:18px;margin:16px 0;box-shadow:var(--shadow);transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease}.card:hover{transform:translateY(-3px);box-shadow:0 22px 50px rgba(15,44,91,.16);border-color:#d4e2ff}.glass{background:rgba(255,255,255,.72);backdrop-filter:blur(18px)}label{font-weight:800;display:block;margin:13px 0 7px;color:#172033}input,select,textarea{width:100%;border:1px solid #d0d7e2;border-radius:14px;padding:13px 14px;font-size:16px;background:#fff;color:#111827;outline:none}input:focus,select:focus,textarea:focus{border-color:#85b5ff;box-shadow:0 0 0 4px rgba(20,95,226,.10)}textarea{min-height:90px}.btn,button{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:linear-gradient(135deg,var(--blue),#0a48b7);color:#fff!important;border:0;border-radius:16px;padding:12px 17px;font-weight:800;font-size:15px;cursor:pointer;box-shadow:0 12px 24px rgba(20,95,226,.22);transition:transform .2s ease,box-shadow .2s ease}.btn:hover,button:hover{transform:translateY(-2px);box-shadow:0 18px 34px rgba(20,95,226,.28)}.btn.light{background:#eff5ff;color:#114db3!important;box-shadow:none;border:1px solid #dbe8ff}.btn.gold{background:linear-gradient(135deg,#e8bd62,#b98021);box-shadow:0 12px 24px rgba(184,128,33,.22)}.grid2,.grid3,.grid4{display:grid;gap:14px}.grid2{grid-template-columns:1fr 1fr}.grid3{grid-template-columns:repeat(3,1fr)}.grid4{grid-template-columns:repeat(4,1fr)}.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.stat{position:relative;overflow:hidden;background:linear-gradient(180deg,#fff,#f8fbff);border:1px solid #e3ecff;border-radius:20px;padding:16px;box-shadow:0 12px 28px rgba(18,98,214,.08);min-height:112px}.stat:after{content:"";position:absolute;right:-32px;top:-36px;width:100px;height:100px;border-radius:50%;background:rgba(20,95,226,.08)}.stat .n{font-size:24px;font-weight:900;color:#0b2a63;line-height:1.1}.stat .t{color:var(--muted);font-size:13px;margin-top:6px}.stat .icon{width:34px;height:34px;border-radius:12px;background:#eff5ff;display:flex;align-items:center;justify-content:center;margin-bottom:10px}.stat.warn .n{color:#b45309}.stat.green .n{color:#15803d}.stat.dark{background:linear-gradient(135deg,#0b2a63,#145fe2);color:#fff}.stat.dark .n,.stat.dark .t{color:#fff}.table-wrap{overflow:auto;border-radius:16px;border:1px solid var(--line)}table{border-collapse:collapse;width:100%;min-width:720px;background:#fff}th,td{border-bottom:1px solid var(--line);padding:12px;text-align:left;vertical-align:top}th{font-weight:900;background:#f8fbff;color:#1d2939;position:sticky;top:0}tr:hover td{background:#fbfdff}.badge{display:inline-block;padding:5px 10px;border-radius:999px;background:#eef3ff;color:#1262d6;font-weight:800;font-size:12px}.badge.green{background:#dcfce7;color:#15803d}.badge.warn{background:#fff7ed;color:#c2410c}.badge.gray{background:#f2f4f7;color:#475467}.notice,.error{border-radius:14px;padding:13px;margin:10px 0}.notice{background:#ecfdf5;color:#047857;border:1px solid #bbf7d0}.error{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}.small{color:#667085;font-size:13px}.nav{position:fixed;bottom:0;left:0;right:0;background:rgba(255,255,255,.93);backdrop-filter:blur(14px);border-top:1px solid #dde6f3;display:flex;justify-content:space-around;z-index:35;box-shadow:0 -12px 28px rgba(15,44,91,.08)}.nav a{padding:12px 5px;color:#374151;font-size:13px;font-weight:800}.nav a:hover{color:var(--blue)}.actions{display:flex;gap:10px;flex-wrap:wrap}.login{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:15px;background:radial-gradient(circle at 20% 0%,rgba(215,166,74,.18),transparent 28%),linear-gradient(180deg,#f7fbff,#eaf4ff)}.login .card{width:100%;max-width:520px}.login-logo{max-width:220px;display:block;margin:0 auto 12px;background:transparent!important;filter:drop-shadow(0 12px 24px rgba(11,42,99,.16))}.dash-hero{position:relative;overflow:hidden;border-radius:28px;padding:22px;margin:14px 0 18px;background:linear-gradient(135deg,rgba(11,42,99,.92),rgba(20,95,226,.82)),url('../img/building-theme.webp') center/cover no-repeat;color:#fff;box-shadow:0 24px 55px rgba(11,42,99,.24)}.dash-hero:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(11,42,99,.80),rgba(11,42,99,.34),rgba(215,166,74,.15));z-index:0}.dash-hero>*{position:relative;z-index:1}.dash-hero h1{color:#fff;margin:0 0 8px}.dash-hero p{margin:0;color:#e9f2ff;max-width:720px}.hero-actions{margin-top:16px;display:flex;gap:10px;flex-wrap:wrap}.project-card{display:grid;grid-template-columns:1.1fr .9fr;gap:18px;align-items:center}.building-tile{min-height:230px;border-radius:22px;background:url('../img/building-card.webp') center/cover no-repeat;position:relative;overflow:hidden;box-shadow:inset 0 -80px 80px rgba(11,42,99,.45)}.building-tile span{position:absolute;left:16px;right:16px;bottom:16px;color:#fff;font-weight:900;font-size:20px;text-shadow:0 2px 12px rgba(0,0,0,.38)}.progress{height:11px;border-radius:999px;background:#e7eef8;overflow:hidden}.progress>i{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#145fe2,#d7a64a);width:var(--w,0%)}.mini-list{display:grid;gap:10px}.mini-row{padding:12px;border-radius:16px;background:#f8fbff;border:1px solid #e3ecff}.mini-row strong{display:block;color:#0b2a63}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px}.app-loader{position:fixed;inset:0;background:linear-gradient(135deg,#061732,#0b2a63 55%,#102e64);display:flex;align-items:center;justify-content:center;z-index:999;transition:opacity .35s ease,visibility .35s ease}.app-loader.hide{opacity:0;visibility:hidden}.loader-box{width:210px;text-align:center;color:#fff;transform-style:preserve-3d;animation:loaderFloat 1.7s ease-in-out infinite}.loader-box img{width:138px;max-height:96px;object-fit:contain;filter:drop-shadow(0 18px 26px rgba(0,0,0,.38));animation:logoPulse 1.25s ease-in-out infinite}.loader-ring{width:82px;height:5px;margin:18px auto 8px;border-radius:999px;background:linear-gradient(90deg,transparent,#d7a64a,#fff,#145fe2,transparent);background-size:220% 100%;animation:ringMove 1s linear infinite}.loader-box b{display:block;font-size:20px;letter-spacing:.03em}.loader-box small{color:#b9cff9}@keyframes loaderFloat{0%,100%{transform:translateY(0) rotateX(0)}50%{transform:translateY(-8px) rotateX(5deg)}}@keyframes logoPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes ringMove{to{background-position:220% 0}}.install-banner{position:sticky;top:64px;z-index:24;margin:0;background:#0f172a;color:#fff;padding:10px 12px;display:none;align-items:center;gap:10px;box-shadow:0 8px 18px rgba(15,23,42,.18)}.install-banner.show{display:flex}.install-banner .ib-text{flex:1;font-size:13px;line-height:1.35}.install-banner .ib-text b{display:block;color:#fff;font-size:14px}.install-banner .ib-actions{display:flex;gap:8px}.install-banner button{width:auto;border-radius:12px;padding:9px 11px;font-size:13px}.install-banner .ib-close{background:#334155!important}.install-help{display:none;position:fixed;left:12px;right:12px;bottom:76px;background:#fff;color:#111827;border:1px solid #dbe3ef;border-radius:18px;padding:16px;box-shadow:0 15px 40px rgba(15,23,42,.22);z-index:50}.install-help.show{display:block}.install-help h3{margin:0 0 8px;font-size:18px}.install-help ol{padding-left:22px;margin:8px 0}.install-help .btn{margin-top:8px;width:100%}.install-mini{margin:10px 0;padding:12px 14px;border-radius:16px;background:#eff6ff;border:1px solid #bfdbfe;color:#1e3a8a;font-size:14px}.install-mini button{margin-top:8px;background:#1262d6;color:#fff;border-radius:12px;padding:9px 13px;width:auto}
@media(max-width:900px){.stats{grid-template-columns:repeat(2,1fr)}.grid4{grid-template-columns:repeat(2,1fr)}.project-card,.two-col{grid-template-columns:1fr}.building-tile{min-height:180px}}
@media(max-width:700px){body{font-size:15px}.topbar{padding:8px 10px;min-height:58px}.brand img{width:58px;max-height:42px}.brand b{font-size:16px}.wrap{padding:13px 10px 86px}.dash-hero{padding:18px;border-radius:22px}.dash-hero h1{font-size:25px}.stats,.grid2,.grid3,.grid4{grid-template-columns:1fr 1fr}.card{border-radius:18px;padding:14px;margin:12px 0}h1{font-size:25px}.stat{min-height:96px;padding:13px}.stat .n{font-size:20px}.btn,button{width:100%;text-align:center}.actions .btn,.hero-actions .btn{width:auto;flex:1}.nav a{font-size:12px;padding:11px 3px}.install-banner{top:58px}.install-banner .ib-actions{flex-direction:column}.install-banner button{padding:8px 9px}.login .card{padding:18px;border-radius:24px}.login-logo{max-width:205px}.table-wrap{border-radius:13px}table{font-size:13px;min-width:660px}th,td{padding:10px}.nav{padding-bottom:env(safe-area-inset-bottom)}}
@media(max-width:430px){.stats,.grid2,.grid3,.grid4{grid-template-columns:1fr}.hero-actions .btn,.actions .btn{width:100%;flex:none}.brand span span{display:none}}
@media print{.topbar,.nav,.no-print,.actions,.app-loader,.install-banner{display:none!important}.wrap{padding:0}.card{box-shadow:none;border:1px solid #ddd}.dash-hero{background:#fff;color:#000;border:1px solid #ddd}.dash-hero h1,.dash-hero p{color:#000}}
