:root{--bg:#0a0a0f;--panel:#16161f;--panel2:#1d1d29;--line:rgba(255,255,255,.09);--gold:#d4a94a;--gold2:#f0c96a;--text:#f7f3e8;--muted:#a8a5b5;--danger:#ef4444;--ok:#22c55e;--warn:#f59e0b;--info:#38bdf8;--shadow:0 24px 70px rgba(0,0,0,.45);--r:8px}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:radial-gradient(circle at 15% 5%,rgba(212,169,74,.13),transparent 30%),var(--bg);color:var(--text);font-family:'DM Sans',system-ui,sans-serif;letter-spacing:0;min-height:100vh}button,input,select,textarea{font:inherit}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:#343241;border-radius:20px}::-webkit-scrollbar-track{background:#0f0f16}
.app-shell{display:grid;grid-template-columns:280px 1fr;min-height:100vh}.sidebar{position:sticky;top:0;height:100vh;padding:26px 18px;background:rgba(14,14,21,.88);border-right:1px solid var(--line);backdrop-filter:blur(18px);display:flex;flex-direction:column;gap:26px}.brand{display:flex;align-items:center;gap:12px;padding:0 8px}.brand-mark{width:42px;height:42px;border:1px solid rgba(240,201,106,.45);display:grid;place-items:center;border-radius:50%;color:var(--gold2);font-family:'Playfair Display',serif;font-weight:800}.brand-name{font-family:'Playfair Display',serif;font-size:25px}.nav{display:grid;gap:8px}.nav button,.nav a{border:0;background:transparent;color:var(--muted);display:flex;align-items:center;gap:12px;padding:12px;border-radius:var(--r);cursor:pointer;text-align:left}.nav button:hover,.nav a:hover,.nav .active{background:rgba(212,169,74,.12);color:var(--text)}.sidebar-footer{margin-top:auto;color:var(--muted);display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--line);padding-top:18px}.main-content{min-width:0}.page-header{padding:28px 34px 18px;display:flex;justify-content:space-between;align-items:center;gap:18px;border-bottom:1px solid var(--line);background:rgba(10,10,15,.65);backdrop-filter:blur(12px);position:sticky;top:0;z-index:8}.page-header h1{font-family:'Playfair Display',serif;margin:0;font-size:34px}.month-nav{display:flex;align-items:center;gap:10px}.month-label{min-width:150px;text-align:center;color:var(--gold2);font-weight:700}.header-balance{text-align:right}.header-balance span{display:block;color:var(--muted);font-size:13px}.header-balance strong{font-size:22px}.page-body{padding:28px 34px 90px}.icon-btn,.btn{border:1px solid var(--line);background:#20202b;color:var(--text);border-radius:var(--r);min-height:42px;padding:0 16px;display:inline-flex;align-items:center;justify-content:center;gap:9px;cursor:pointer;transition:.2s}.icon-btn{width:42px;padding:0}.btn:hover,.icon-btn:hover{border-color:rgba(240,201,106,.5);transform:translateY(-1px)}.btn.primary{background:linear-gradient(135deg,var(--gold),var(--gold2));color:#15100a;border:0;font-weight:800}.btn.danger{background:rgba(239,68,68,.14);border-color:rgba(239,68,68,.35);color:#fecaca}.grid{display:grid;gap:18px}.summary-grid{grid-template-columns:repeat(4,minmax(0,1fr));margin-bottom:20px}.card{background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.02));border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow)}.summary-card{padding:20px;position:relative;overflow:hidden}.summary-card:before{content:"";position:absolute;inset:auto -40px -60px auto;width:140px;height:140px;background:rgba(212,169,74,.11);border-radius:50%}.summary-card .label{color:var(--muted);font-size:13px}.summary-card .value{font-size:27px;font-weight:800;margin:10px 0 4px}.summary-card .var{font-size:12px;color:var(--muted)}.content-grid{grid-template-columns:1fr 1fr}.panel{padding:20px}.panel-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px}.panel h2{font-size:18px;margin:0}.chart-wrap{min-height:300px;position:relative}.legend{display:grid;gap:9px;margin-top:12px}.legend-item{display:flex;justify-content:space-between;color:var(--muted);font-size:13px}.dot{width:10px;height:10px;border-radius:50%;display:inline-block;margin-right:8px}.cards-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}.credit-card{padding:18px;min-height:145px;display:flex;flex-direction:column;justify-content:space-between;background:linear-gradient(135deg,var(--card-color),#111118);border:1px solid rgba(255,255,255,.12);border-radius:var(--r);box-shadow:var(--shadow)}.credit-card .flag{text-transform:uppercase;color:rgba(255,255,255,.72);font-size:12px}.badge{display:inline-flex;align-items:center;border-radius:999px;padding:5px 9px;font-size:12px;border:1px solid var(--line);color:var(--muted)}.badge.pago{color:#bbf7d0;border-color:rgba(34,197,94,.35);background:rgba(34,197,94,.1)}.badge.pendente,.badge.vencido{color:#fed7aa;border-color:rgba(245,158,11,.35);background:rgba(245,158,11,.1)}.badge.vencido{color:#fecaca;border-color:rgba(239,68,68,.35);background:rgba(239,68,68,.1)}.table-panel{margin-top:20px}.toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.search,.field input,.field select,.field textarea{width:100%;background:#111119;color:var(--text);border:1px solid var(--line);border-radius:var(--r);min-height:42px;padding:10px 12px;outline:none}.search{max-width:260px}.field input:focus,.field select:focus,.field textarea:focus,.search:focus{border-color:rgba(240,201,106,.55);box-shadow:0 0 0 3px rgba(212,169,74,.09)}.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:var(--r)}table{width:100%;border-collapse:collapse;min-width:760px}th,td{padding:13px 14px;border-bottom:1px solid var(--line);text-align:left}th{color:var(--muted);font-size:12px;text-transform:uppercase}td.actions{white-space:nowrap}.empty{padding:30px;text-align:center;color:var(--muted)}.modal{position:fixed;inset:0;display:none;place-items:center;background:rgba(0,0,0,.64);z-index:40;padding:20px}.modal.open{display:grid;animation:fadeIn .18s ease}.modal-card{width:min(680px,100%);max-height:92vh;overflow:auto;background:rgba(22,22,31,.96);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow)}.modal-head,.modal-actions{padding:18px 20px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--line)}.modal-actions{border-top:1px solid var(--line);border-bottom:0;justify-content:flex-end}.modal-body{padding:20px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.field.full{grid-column:1/-1}.field label{display:block;color:var(--muted);font-size:13px;margin-bottom:7px}.switch{display:flex;align-items:center;gap:10px;color:var(--muted);cursor:pointer}.switch input{width:18px;height:18px}.fab{position:fixed;right:26px;bottom:26px;z-index:30}.fab-main{width:58px;height:58px;border-radius:50%;border:0;background:linear-gradient(135deg,var(--gold),var(--gold2));color:#16100a;box-shadow:var(--shadow);cursor:pointer}.fab-menu{position:absolute;right:0;bottom:70px;display:none;gap:9px;flex-direction:column}.fab.open .fab-menu{display:flex;animation:fadeInUp .2s ease}.toast-container{position:fixed;right:20px;top:20px;z-index:80;display:grid;gap:10px}.toast{background:#171721;border:1px solid var(--line);border-left:4px solid var(--gold);padding:14px 16px;border-radius:var(--r);box-shadow:var(--shadow);animation:toastIn .24s ease}.toast.ok{border-left-color:var(--ok)}.toast.erro{border-left-color:var(--danger)}.skeleton{background:linear-gradient(90deg,#171721,#242431,#171721);background-size:220% 100%;animation:shimmer 1.2s infinite}.login-page{min-height:100vh;display:grid;place-items:center;overflow:hidden;background:#0a0a0f;position:relative}.particles{position:absolute;inset:0;background-image:radial-gradient(circle,rgba(240,201,106,.32) 1px,transparent 1px);background-size:42px 42px;animation:spin 42s linear infinite;opacity:.35}.login-card{position:relative;width:min(420px,calc(100% - 36px));padding:34px;background:rgba(22,22,31,.72);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);backdrop-filter:blur(18px);animation:fadeInUp .45s ease}.login-card h1{font-family:'Playfair Display',serif;font-size:46px;margin:0;text-align:center}.login-card p{text-align:center;color:var(--muted);margin:8px 0 26px}.password-row{display:flex;gap:8px}.error{color:#fecaca;background:rgba(239,68,68,.12);border:1px solid rgba(239,68,68,.28);padding:10px;border-radius:var(--r);margin-bottom:14px;animation:shake .35s ease}.install-page{min-height:100vh;display:grid;place-items:center;padding:24px;background:var(--bg)}.install-card{width:min(760px,100%);padding:28px}.log{background:#0f0f16;border:1px solid var(--line);border-radius:var(--r);padding:14px;max-height:320px;overflow:auto;color:var(--muted)}@keyframes fadeInUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{to{background-position:-220% 0}}@keyframes shake{20%,60%{transform:translateX(-6px)}40%,80%{transform:translateX(6px)}}@keyframes toastIn{from{opacity:0;transform:translateX(18px)}to{opacity:1;transform:none}}@keyframes toastOut{to{opacity:0;transform:translateX(18px)}}@media(max-width:1100px){.app-shell{grid-template-columns:86px 1fr}.brand-name,.nav span,.sidebar-footer span{display:none}.summary-grid{grid-template-columns:repeat(2,1fr)}.content-grid{grid-template-columns:1fr}.sidebar{padding:22px 12px}.nav button,.nav a{justify-content:center}}@media(max-width:720px){.app-shell{display:block}.sidebar{position:relative;height:auto;flex-direction:row;overflow:auto}.brand{min-width:max-content}.nav{display:flex}.sidebar-footer{display:none}.page-header{position:relative;padding:20px;align-items:flex-start;flex-direction:column}.page-body{padding:20px 14px 88px}.summary-grid{grid-template-columns:1fr}.form-grid{grid-template-columns:1fr}.toolbar{align-items:stretch}.search{max-width:none}.cards-list{grid-template-columns:1fr}.header-balance{text-align:left}.page-header h1{font-size:30px}}
