:root{
  --bg:#eef3fb;--card:#ffffff;--ink:#101828;--muted:#667085;--primary:#2563eb;--primary2:#7c3aed;--cyan:#06b6d4;--green:#16a34a;--red:#ef4444;--amber:#f59e0b;--line:#e5eaf3;--shadow:0 24px 70px rgba(16,24,40,.11);--shadow2:0 12px 32px rgba(153,72,198,.18);--radius:28px
}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,Segoe UI,system-ui,Arial,sans-serif;background:radial-gradient(circle at 12% -10%,rgba(37,99,235,.22),transparent 35%),radial-gradient(circle at 90% 8%,rgba(124,58,237,.18),transparent 32%),linear-gradient(135deg,#f8fbff,#eef3fb 50%,#f7f5ff);color:var(--ink)}a{text-decoration:none;color:inherit}.shell{display:grid;grid-template-columns:292px 1fr;min-height:100vh}.sidebar{background:linear-gradient(180deg,#06142e,#08111f 55%,#0f172a);color:#fff;padding:24px 18px;position:sticky;top:0;height:100vh;box-shadow:18px 0 60px rgba(2,6,23,.18);z-index:20}.brand{display:flex;gap:12px;align-items:center;margin-bottom:30px;padding:8px}.logo,.brand-logo-img{width:54px;height:54px;border-radius:18px;display:grid;place-items:center;font-weight:950;letter-spacing:-.05em;background:linear-gradient(135deg,#22d3ee,#2563eb 45%,#ec4899);box-shadow:0 16px 42px rgba(37,99,235,.45);object-fit:cover}.brand strong{font-size:17px}.brand span{display:block;color:#aab6ca;font-size:12px;margin-top:4px}.sidebar nav{display:grid;gap:8px}.sidebar a{padding:14px 15px;border-radius:18px;color:#d8e2f3;display:flex;gap:12px;align-items:center;font-weight:800;transition:.18s}.sidebar a span{width:24px;text-align:center;opacity:.95}.sidebar a:hover{background:rgba(255,255,255,.10);color:#fff;transform:translateX(4px)}.sidebar .logout{color:#fecaca;margin-top:16px}.main{min-width:0}.topbar{height:92px;display:flex;align-items:center;justify-content:space-between;padding:0 34px}.topbar h1{margin:0;font-size:30px;letter-spacing:-.04em}.topbar p{margin:5px 0 0;color:var(--muted)}.menuBtn{display:none;border:0;background:white;border-radius:14px;padding:11px 14px;box-shadow:var(--shadow)}.topActions{display:flex;align-items:center;gap:12px}.searchPill{background:rgba(255,255,255,.78);border:1px solid rgba(255,255,255,.75);color:#8a94a6;border-radius:999px;padding:13px 22px;min-width:290px;box-shadow:0 10px 28px rgba(16,24,40,.06)}.notif{position:relative;background:white;width:46px;height:46px;border-radius:16px;display:grid;place-items:center;box-shadow:0 10px 28px rgba(16,24,40,.08)}.notif b{position:absolute;right:-3px;top:-4px;background:#ef4444;color:#fff;border-radius:999px;font-size:11px;padding:2px 6px}.avatar,.avatar-img{width:48px;height:48px;border-radius:17px;background:linear-gradient(135deg,#111827,#475569);color:#fff;display:grid;place-items:center;font-weight:900;object-fit:cover;box-shadow:0 12px 30px rgba(16,24,40,.16)}.content{padding:0 34px 44px}.grid{display:grid;gap:22px}.cards{grid-template-columns:repeat(4,minmax(0,1fr))}.card{background:rgba(255,255,255,.84);backdrop-filter:blur(18px);border:1px solid rgba(255,255,255,.78);box-shadow:var(--shadow);border-radius:var(--radius);padding:24px}.metric{position:relative;overflow:hidden;min-height:145px}.metric:before{content:"";position:absolute;right:-35px;top:-35px;width:130px;height:130px;border-radius:999px;background:linear-gradient(135deg,rgba(37,99,235,.15),rgba(124,58,237,.10))}.metricIcon{width:58px;height:58px;border-radius:20px;display:grid;place-items:center;font-size:24px;margin-bottom:18px}.metric small{color:var(--muted);font-weight:800}.metric b{font-size:28px;display:block;margin-top:8px;letter-spacing:-.03em}.income .metricIcon{background:#dcfce7;color:var(--green)}.expense .metricIcon{background:#fee2e2;color:var(--red)}.balance .metricIcon{background:#dbeafe;color:var(--primary)}.count .metricIcon{background:#fef3c7;color:var(--amber)}.income b{color:var(--green)}.expense b{color:var(--red)}.toolbar{display:flex;gap:14px;align-items:center;justify-content:space-between;margin:26px 0;flex-wrap:wrap}.toolbar h2{letter-spacing:-.04em}.btn{border:0;border-radius:16px;padding:12px 18px;background:#e8eef8;color:#172033;font-weight:900;cursor:pointer;display:inline-flex;gap:8px;align-items:center;justify-content:center;transition:.18s}.btn:hover{transform:translateY(-2px);box-shadow:0 14px 28px rgba(16,24,40,.10)}.btn.primary{background:linear-gradient(135deg,#8b5cf6,#5c1279);color:#fff;box-shadow:var(--shadow2)}.btn.danger{background:#fee2e2;color:#991b1b}.btn.success{background:#dcfce7;color:#166534}.btn.small{padding:8px 10px;border-radius:11px;font-size:13px}.tableWrap{overflow:auto;border-radius:24px;background:rgba(255,255,255,.88);box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.86)}table{width:100%;border-collapse:collapse;min-width:940px}th,td{padding:16px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}th{font-size:12px;text-transform:uppercase;color:#667085;background:#f8fafc;letter-spacing:.06em}.badge{display:inline-flex;padding:6px 11px;border-radius:999px;background:#eef2ff;color:#3730a3;font-size:12px;font-weight:900}.badge.green{background:#dcfce7;color:#166534}.badge.red{background:#fee2e2;color:#991b1b}.badge.gray{background:#f1f5f9;color:#475569}.form{display:grid;gap:15px}.form.two{grid-template-columns:repeat(2,1fr)}label{display:grid;gap:7px;font-weight:900;color:#263248}input,select,textarea{width:100%;border:1px solid #dbe3ef;border-radius:15px;padding:13px 14px;font:inherit;background:#fff;outline:none}input:focus,select:focus,textarea:focus{border-color:#d8b4fe;box-shadow:0 0 0 4px rgba(59,130,246,.13)}textarea{min-height:92px}.modal{position:fixed;inset:0;background:rgba(3,7,18,.60);display:none;align-items:flex-start;justify-content:center;padding:40px 18px;overflow:auto;z-index:50}.modal.show{display:flex}.modalBox{background:#fff;width:min(980px,100%);border-radius:30px;box-shadow:0 30px 90px rgba(0,0,0,.28);padding:24px}.modalHead{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}.evidence-block{border:1px dashed #bfcef0;background:#f8fbff;border-radius:22px;padding:16px;margin-top:12px}.alert{padding:14px 18px;border-radius:18px;margin-bottom:18px;font-weight:900}.alert-success{background:#dcfce7;color:#166534}.alert-error{background:#fee2e2;color:#991b1b}.filters{display:grid;grid-template-columns:repeat(5,minmax(150px,1fr));gap:12px;width:100%}.hero{min-height:100vh;position:relative;overflow:hidden;display:grid;grid-template-columns:1.1fr .9fr;gap:34px;align-items:center;padding:54px;max-width:1240px;margin:auto}.hero:before{content:"";position:absolute;inset:28px;border-radius:44px;background:linear-gradient(135deg,rgba(255,255,255,.54),rgba(255,255,255,.18));border:1px solid rgba(255,255,255,.65);z-index:-2}.orb{position:absolute;border-radius:999px;filter:blur(2px);opacity:.8;animation:float 7s ease-in-out infinite}.orb.one{width:230px;height:230px;background:rgba(153,72,198,.18);left:-40px;top:80px}.orb.two{width:180px;height:180px;background:rgba(16,185,129,.16);right:38%;bottom:70px;animation-delay:1.7s}.orb.three{width:270px;height:270px;background:rgba(236,72,153,.14);right:-60px;top:20px;animation-delay:.8s}@keyframes float{50%{transform:translateY(-18px) translateX(10px)}}.hero h1{font-size:64px;line-height:.98;margin:14px 0;letter-spacing:-.07em}.hero p{color:#526079;font-size:19px;line-height:1.65}.heroMark{display:inline-flex;gap:10px;align-items:center;background:rgba(255,255,255,.78);border:1px solid rgba(255,255,255,.8);border-radius:999px;padding:10px 14px;font-weight:950;color:#5c1279;box-shadow:0 12px 30px rgba(153,72,198,.10)}.heroStats{display:flex;gap:14px;flex-wrap:wrap;margin:25px 0}.heroStat{background:rgba(255,255,255,.78);border:1px solid rgba(255,255,255,.76);padding:15px 18px;border-radius:22px;min-width:150px}.heroStat b{font-size:22px}.loginCard{background:rgba(255,255,255,.90);backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.82);border-radius:34px;box-shadow:var(--shadow);padding:30px;position:relative;overflow:hidden}.loginCard:before{content:"";position:absolute;right:-60px;top:-70px;width:210px;height:210px;border-radius:999px;background:linear-gradient(135deg,rgba(153,72,198,.16),rgba(124,58,237,.14))}.loginCard>*{position:relative}.features{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:24px}.feature{background:rgba(255,255,255,.72);padding:18px;border-radius:22px;border:1px solid rgba(255,255,255,.80);box-shadow:0 12px 35px rgba(16,24,40,.06)}.featureIcon{font-size:24px;margin-bottom:8px}.bankGrid{grid-template-columns:repeat(2,minmax(0,1fr));margin:24px 0}.bankCard{display:flex;align-items:center;gap:20px;position:relative;overflow:hidden}.bankCard:after{content:"";position:absolute;right:-42px;bottom:-42px;width:140px;height:140px;border-radius:999px;background:rgba(153,72,198,.08)}.bankLogo,.bankLogoImg{width:86px;height:86px;border-radius:24px;display:grid;place-items:center;background:linear-gradient(135deg,#eff6ff,#dbeafe);font-size:38px;object-fit:cover;box-shadow:inset 0 0 0 1px rgba(153,72,198,.10)}.bankInfo h3{margin:0 0 8px}.bankInfo p{margin:4px 0;color:#344054}.bankInfo b{font-size:20px}.miniChart{height:96px;display:flex;align-items:flex-end;gap:8px;margin-top:18px}.miniChart span{flex:1;border-radius:999px 999px 8px 8px;background:linear-gradient(180deg,#c084fc,#5c1279);min-height:20px;opacity:.85}.sectionTitle{display:flex;align-items:center;justify-content:space-between;margin:28px 0 14px}.profilePreview{display:flex;align-items:center;gap:16px}.profilePreview img,.profilePreview .avatar{width:72px;height:72px;border-radius:24px}.empty{padding:36px;text-align:center;color:var(--muted)}
@media(max-width:1100px){.shell{grid-template-columns:86px 1fr}.sidebar{padding:18px 10px}.brand div:not(.logo){display:none}.sidebar a{justify-content:center}.sidebar a span{width:auto}.sidebar a{font-size:0}.sidebar a span{font-size:18px}.cards{grid-template-columns:repeat(2,1fr)}.bankGrid{grid-template-columns:1fr}.searchPill{display:none}}
@media(max-width:780px){.shell{display:block}.sidebar{position:fixed;left:-300px;transition:.22s;width:280px}.open .sidebar{left:0}.menuBtn{display:block}.topbar{padding:0 18px}.content{padding:0 18px 36px}.hero{grid-template-columns:1fr;padding:26px}.hero h1{font-size:42px}.features,.cards,.form.two,.filters{grid-template-columns:1fr}.bankCard{align-items:flex-start}.topTitle p{display:none}}
@media(max-width:460px){.metric b{font-size:23px}.card{padding:19px}.topbar h1{font-size:24px}.heroStats{display:grid}.loginCard{padding:22px}.bankLogo,.bankLogoImg{width:68px;height:68px}}
.muted{color:var(--muted);margin:6px 0 0}.tiny{font-size:13px;line-height:1.5}.moneyFlow{display:flex;gap:12px;margin-top:22px;flex-wrap:wrap}.moneyFlow span{width:58px;height:58px;border-radius:20px;display:grid;place-items:center;background:rgba(255,255,255,.72);border:1px solid rgba(255,255,255,.8);box-shadow:0 15px 38px rgba(16,24,40,.08);font-size:25px;animation:float 6s ease-in-out infinite}.moneyFlow span:nth-child(2){animation-delay:.4s}.moneyFlow span:nth-child(3){animation-delay:.8s}.moneyFlow span:nth-child(4){animation-delay:1.2s}.moneyFlow span:nth-child(5){animation-delay:1.6s}.roleHero{display:grid;grid-template-columns:1.3fr .7fr;gap:22px;align-items:center;background:linear-gradient(135deg,rgba(255,255,255,.92),rgba(239,246,255,.84));position:relative;overflow:hidden}.roleHero:after{content:"";position:absolute;right:-80px;top:-80px;width:240px;height:240px;border-radius:999px;background:linear-gradient(135deg,rgba(153,72,198,.18),rgba(124,58,237,.14))}.roleHero>*{position:relative}.roleHero h2{font-size:36px;letter-spacing:-.05em;margin:14px 0 8px}.roleHero p{color:var(--muted);font-size:16px;line-height:1.7}.rolePills{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.inlineForm{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.inlineForm select{min-width:128px;padding:9px 11px;border-radius:12px}.registerHero .features{grid-template-columns:1fr}.topbar{background:linear-gradient(90deg,rgba(255,255,255,.15),rgba(255,255,255,.45));backdrop-filter:blur(14px);position:sticky;top:0;z-index:10}.sidebar nav a[href$="roles.php"]{background:rgba(124,58,237,.12)}.sectionTitle p{max-width:640px}.tableWrap small{color:var(--muted)}
@media(max-width:780px){.roleHero{grid-template-columns:1fr}.rolePills{justify-content:flex-start}.roleHero h2{font-size:28px}.moneyFlow span{width:50px;height:50px}}

/* Mobile-first production polish */
.sidebar a.active{background:rgba(255,255,255,.13);color:#fff;box-shadow:inset 0 0 0 1px rgba(255,255,255,.06)}
.cardActions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-top:14px}.cardActions form{margin:0}.mobileNav,.mobileShade{display:none}
.systemTop{display:flex;justify-content:space-between;gap:18px;align-items:center;margin-bottom:22px}.systemShell{min-height:100vh;padding:26px;background:radial-gradient(circle at 8% 0,rgba(153,72,198,.18),transparent 30%),radial-gradient(circle at 92% 8%,rgba(124,58,237,.16),transparent 28%),#eef3fb}.systemHeader{background:#071426;color:white;border-radius:30px;padding:26px;box-shadow:var(--shadow)}.systemHeader h1{margin:0;font-size:36px;letter-spacing:-.05em}.systemGrid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.systemCard{background:white;border-radius:24px;padding:20px;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.8)}
@media(max-width:780px){
  body{background:#f3f6fb}.shell{display:block}.main{width:100%;padding-bottom:86px}.sidebar{position:fixed;left:-86%;top:0;width:min(82vw,320px);height:100dvh;overflow:auto;padding:18px 14px;transition:.22s;z-index:60;border-radius:0 26px 26px 0}.open .sidebar{left:0}.open .mobileShade{display:block;position:fixed;inset:0;background:rgba(2,6,23,.48);z-index:55}.open .sidebar a{font-size:15px;justify-content:flex-start}.open .sidebar a span{width:24px;font-size:18px}.open .brand div{display:block}.open .brand{margin-bottom:18px}.menuBtn{display:grid;place-items:center}.mobileNav{display:grid;grid-template-columns:repeat(5,1fr);position:fixed;left:12px;right:12px;bottom:10px;z-index:40;background:rgba(255,255,255,.94);backdrop-filter:blur(18px);border:1px solid rgba(255,255,255,.9);border-radius:24px;box-shadow:0 18px 55px rgba(16,24,40,.18);padding:8px}.mobileNav a{display:grid;gap:2px;place-items:center;color:#64748b;font-weight:900;font-size:16px}.mobileNav a small{font-size:10px}.mobileNav a.active{color:#2563eb}.topbar{height:76px;padding:0 14px}.topbar h1{font-size:22px}.topActions{gap:8px}.notif,.avatar,.avatar-img{width:42px;height:42px;border-radius:15px}.content{padding:0 14px 32px}.card{border-radius:24px;padding:18px;box-shadow:0 12px 36px rgba(16,24,40,.08)}.cards{grid-template-columns:1fr;gap:14px}.metric{min-height:112px;display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:center}.metricIcon{margin:0}.metric b{font-size:24px;word-break:break-word}.toolbar{display:grid;gap:12px}.toolbar .btn,.filters .btn{width:100%}.tableWrap{box-shadow:none;border-radius:22px}.tableWrap table{min-width:760px}.bankGrid{grid-template-columns:1fr;gap:14px}.bankCard{display:grid;grid-template-columns:64px 1fr;gap:14px}.bankLogo,.bankLogoImg{width:64px;height:64px;border-radius:20px;font-size:28px}.sectionTitle{display:grid;gap:10px;align-items:start}.inlineForm{display:grid}.inlineForm select,.inlineForm button{width:100%}.modal{padding:10px}.modalBox{border-radius:24px;max-height:94dvh;overflow:auto;padding:18px}.hero{min-height:auto;padding:18px}.hero:before{inset:8px;border-radius:28px}.hero h1{font-size:34px}.hero p{font-size:16px}.loginCard{border-radius:26px;padding:18px}.form.two,.filters{grid-template-columns:1fr}.systemGrid{grid-template-columns:1fr}.systemTop{display:grid}.systemHeader h1{font-size:28px}}
@media(max-width:420px){.content{padding-left:10px;padding-right:10px}.mobileNav{left:8px;right:8px;border-radius:20px}.mobileNav a small{font-size:9px}.card{padding:15px}.bankCard{grid-template-columns:52px 1fr}.bankLogo,.bankLogoImg{width:52px;height:52px;border-radius:16px;font-size:24px}}

/* Brand polish */
.welcomeLogo{width:min(280px,74vw);height:auto;display:block;margin:0 0 18px;filter:drop-shadow(0 16px 26px rgba(15,23,42,.12))}.welcomeLogo.small{width:min(210px,68vw);margin-bottom:16px}.brand-logo-img.app-brand-logo{object-fit:contain;background:rgba(255,255,255,.08);padding:5px}.brand-logo-img{object-fit:contain}.sidebar .brand{min-height:64px}.hero .welcomeLogo + .heroMark{margin-top:2px}@media(max-width:760px){.welcomeLogo{width:min(220px,70vw);margin-inline:auto}.hero{text-align:left}.loginCard{text-align:left}.features{grid-template-columns:1fr}.heroStats{display:grid;grid-template-columns:1fr 1fr}.heroStat{min-width:0}.moneyFlow{justify-content:center}}


/* PWA / install and ZOE logo polish */
.installBtn{border:0;border-radius:16px;padding:12px 16px;background:linear-gradient(135deg,#5c1279,#9948c6);color:#fff;font-weight:950;box-shadow:0 14px 34px rgba(17,24,39,.18);cursor:pointer;white-space:nowrap}.installBtn:hover{transform:translateY(-2px)}.installHero{margin-top:22px}.welcomeLogo{width:min(420px,86vw);max-height:none;height:auto;background:transparent!important;border-radius:0!important;padding:0!important;object-fit:contain;box-shadow:0 18px 45px rgba(124,0,93,.10);filter:drop-shadow(0 16px 22px rgba(15,23,42,.10))}.welcomeLogo.small{width:min(300px,78vw);max-height:none}.brand-logo-img.app-brand-logo{background:transparent!important;padding:0!important;border-radius:0!important;width:170px!important;height:auto!important;max-height:62px;object-fit:contain;object-position:left center}.brand-logo-img{object-fit:contain}.sidebar .brand{gap:12px}.sidebar .brand .brand-logo-img{width:170px!important;height:auto!important;max-height:62px;object-fit:contain}.topActions .installBtn{padding:11px 14px;font-size:13px}@media(max-width:1100px){.shell{grid-template-columns:92px 1fr}.sidebar .brand .brand-logo-img{width:62px!important;height:62px!important;object-fit:contain}.open .sidebar .brand .brand-logo-img{width:170px!important;height:auto!important;max-height:62px}}@media(max-width:780px){.topActions .installBtn{display:none}.installHero{width:100%;margin-top:16px}.welcomeLogo{width:min(340px,82vw)}.welcomeLogo.small{width:min(260px,76vw)}.sidebar .brand .brand-logo-img{width:56px!important;height:56px!important}.open .sidebar .brand .brand-logo-img{width:168px!important;height:auto!important;max-height:62px}.heroStats{grid-template-columns:1fr}.features{gap:12px}}
@media(display-mode:standalone){.installBtn{display:none!important}}
