
:root {
  --bg:#0b1020; --side:#070b16; --panel:rgba(255,255,255,.075); --panel2:rgba(255,255,255,.12);
  --text:#e5e7eb; --muted:#94a3b8; --accent:#38bdf8; --good:#22c55e; --danger:#ef4444;
}
*{box-sizing:border-box} html,body{max-width:100%;overflow-x:hidden} body{margin:0;background:radial-gradient(circle at top right,rgba(56,189,248,.20),transparent 35%),radial-gradient(circle at bottom left,rgba(168,85,247,.18),transparent 40%),var(--bg);color:var(--text);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}
.layout{display:grid;grid-template-columns:280px minmax(0,1fr);min-height:100vh}
.mobile-topbar,.nav-backdrop{display:none}
.sidebar{position:sticky;top:0;height:100vh;background:rgba(7,11,22,.92);border-right:1px solid rgba(255,255,255,.10);padding:24px;display:flex;flex-direction:column;gap:24px}
.brand{display:flex;gap:12px;align-items:center;color:var(--text);text-decoration:none}.brand:hover{color:var(--text)}.brand span{display:block;color:var(--muted);font-size:12px}.logo{width:44px;height:44px;border-radius:16px;background:linear-gradient(135deg,var(--accent),#a855f7);display:grid;place-items:center;font-weight:900;color:#06111f}
.menu{display:grid;gap:8px}.menu a,.language a{color:var(--muted);text-decoration:none;padding:12px 14px;border-radius:14px}.menu a.active,.menu a:hover,.language a.selected{background:rgba(56,189,248,.14);color:var(--text)}
.menu-logout{margin:8px 0 0}.menu-logout button{width:100%;background:rgba(255,255,255,.08);color:var(--muted)}
.language{margin-top:auto}.language span{display:block;color:var(--muted);font-size:12px;margin-bottom:8px}.language div{display:grid;gap:6px}
.main{padding:32px;max-width:1400px;width:100%;min-width:0;margin:0 auto}
.flash-stack{display:grid;gap:10px;margin-bottom:16px}.flash{padding:12px 14px;border-radius:12px;background:rgba(56,189,248,.16);border:1px solid rgba(56,189,248,.32)}.flash.error{background:rgba(239,68,68,.16);border-color:rgba(239,68,68,.42)}
.hero{display:flex;justify-content:space-between;gap:24px;padding:30px;border-radius:28px;background:linear-gradient(135deg,rgba(255,255,255,.13),rgba(255,255,255,.04));border:1px solid rgba(255,255,255,.12);box-shadow:0 24px 90px rgba(0,0,0,.25);margin-bottom:22px}.hero.small{align-items:center}
.eyebrow{color:var(--accent);text-transform:uppercase;letter-spacing:.16em;font-size:12px;margin:0 0 8px}h1{font-size:clamp(34px,4vw,56px);margin:0;line-height:1}h2{margin-top:0}.sub{color:var(--muted);max-width:760px}
.hero-card{min-width:280px;padding:24px;border-radius:24px;background:rgba(10,16,32,.78);border:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;justify-content:center}.hero-card span,.card span{color:var(--muted)}.hero-card strong{font-size:38px;margin:8px 0}
.cards{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-bottom:18px}.card,.panel{min-width:0;background:var(--panel);border:1px solid rgba(255,255,255,.12);border-radius:24px;padding:22px;backdrop-filter:blur(12px);box-shadow:0 14px 45px rgba(0,0,0,.18)}.card strong{display:block;font-size:26px;margin-top:8px}.card small{color:var(--muted)}
.grid{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);gap:18px}.wide{grid-column:span 1}.form{display:grid;gap:12px}.form.two{grid-template-columns:1fr 1fr}.form .full{grid-column:1/-1}label{display:grid;gap:6px;color:var(--muted)}input,select,textarea{width:100%;font-size:16px;padding:12px 14px;border-radius:14px;border:1px solid rgba(255,255,255,.16);background:rgba(8,13,28,.9);color:var(--text)}textarea{min-height:150px}
.income-register-form{margin-top:12px}.history-filter{grid-template-columns:minmax(180px,260px) auto;align-items:end;margin-bottom:16px}.inline-form input{max-width:120px;padding:9px 11px}.toolbar-row{display:flex;gap:10px;flex-wrap:wrap;margin:0 0 18px}.toolbar-groups{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin:0 0 18px}.toolbar-group{background:var(--panel);border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:14px;display:flex;gap:8px;flex-wrap:wrap;align-items:center}.toolbar-group span{width:100%;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.08em}.toolbar-group button{padding:10px 12px}.collapsible-panel>summary{cursor:pointer;list-style:none;font-size:20px;font-weight:800;margin:-4px 0 16px}.collapsible-panel>summary::-webkit-details-marker{display:none}.collapsible-panel>summary::after{content:"-";float:right;color:var(--accent)}.collapsible-panel:not([open])>summary{margin-bottom:0}.collapsible-panel:not([open])>summary::after{content:"+"}.drawer-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.45);opacity:0;pointer-events:none;transition:.18s ease;z-index:50}.drawer-panel{position:fixed;top:0;right:0;width:min(460px,100vw);height:100vh;background:#0b1020;border-left:1px solid rgba(255,255,255,.14);box-shadow:-24px 0 70px rgba(0,0,0,.45);padding:22px;transform:translateX(100%);transition:.22s ease;z-index:60;overflow:auto}.drawer-panel.open{transform:translateX(0)}body.drawer-active .drawer-backdrop{opacity:1;pointer-events:auto}.drawer-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}.drawer-head h2{margin:0}.drawer-head button{background:rgba(255,255,255,.1);color:var(--text);font-size:22px;line-height:1;padding:8px 12px}
button{border:0;min-height:44px;padding:12px 16px;border-radius:14px;background:var(--accent);font-weight:800;color:#06111f;cursor:pointer}.danger{background:var(--danger);color:#fff}
.compact-action{width:max-content;min-width:160px;justify-self:start}
table{width:100%;border-collapse:collapse}th,td{padding:12px;border-bottom:1px solid rgba(255,255,255,.12);text-align:left}th{color:var(--muted)}
.month-nav{display:flex;align-items:center;justify-content:center;gap:18px;margin:-6px 0 18px}.month-nav a{color:var(--accent);text-decoration:none;font-weight:800}.month-nav strong{font-size:18px}.edit-row td{background:rgba(255,255,255,.035);padding:8px 12px}.edit-row summary{cursor:pointer;color:var(--accent);font-weight:800}.form-inline-edit{grid-template-columns:repeat(3,minmax(0,1fr));padding-top:12px}.form-inline-edit button{align-self:end}
.allocation-table{display:grid;gap:14px}.alloc-row{display:grid;grid-template-columns:130px 1fr 170px;gap:14px;align-items:center}.bar{height:12px;background:rgba(255,255,255,.12);border-radius:99px;overflow:hidden}.bar i{display:block;height:100%;background:linear-gradient(90deg,var(--accent),var(--good))}
.portfolio-stack{display:grid;gap:18px}.portfolio-summary{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.portfolio-actions-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:18px}.action-panel{padding:0;overflow:hidden}.action-panel summary{cursor:pointer;list-style:none;padding:16px 18px;font-weight:900;color:var(--text)}.action-panel summary::-webkit-details-marker{display:none}.action-panel summary::after{content:"+";float:right;color:var(--accent);font-size:18px}.action-panel[open] summary{border-bottom:1px solid rgba(255,255,255,.12);background:rgba(56,189,248,.10)}.action-panel[open] summary::after{content:"-"}.action-panel .form{padding:18px}.action-panel form:not(.form){padding:18px}.section-title{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;margin-bottom:16px}.section-title h2{margin:0}.section-title strong{font-size:22px}.allocation-split{display:grid;grid-template-columns:320px minmax(0,1fr);gap:22px;align-items:center}.chart-box{min-height:260px;display:grid;place-items:center}.table-wrap{width:100%;overflow:auto}.compact-table th,.compact-table td{padding:10px 12px;white-space:nowrap}.actions{display:flex;gap:8px;align-items:center;justify-content:flex-end}.inline-form{display:inline-flex;margin:0}.inline-form button{padding:9px 11px}.pill{display:inline-flex;align-items:center;border-radius:999px;padding:5px 9px;font-size:12px;font-weight:800}.pill.good{background:rgba(34,197,94,.16);color:#86efac}.pill.warn{background:rgba(250,204,21,.14);color:#fde68a}.positive{color:#86efac}.negative{color:#fca5a5}
.scenario-text{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.scenario-text div,.journal-item{background:rgba(255,255,255,.06);border-radius:18px;padding:16px}.journal-item{margin-bottom:12px}.journal-item span{display:block;color:var(--accent);margin:6px 0}.journal-item p{color:var(--muted)}
canvas{max-height:430px}
.login-screen{min-height:100vh;display:grid;place-items:center;padding:20px}.login-panel{width:min(440px,100%)}.login-brand{margin-bottom:22px}.login-panel h1{font-size:32px;margin-bottom:20px}.login-language{margin-top:22px}
@media(max-width:1200px){.portfolio-summary{grid-template-columns:repeat(2,minmax(0,1fr))}.allocation-split{grid-template-columns:1fr}}
@media(max-width:1000px){.layout{grid-template-columns:1fr}.cards,.grid,.scenario-text,.form.two,.portfolio-actions-grid,.toolbar-groups{grid-template-columns:1fr}.hero{display:grid}.alloc-row{grid-template-columns:1fr}.actions{justify-content:flex-start;flex-wrap:wrap}}
@media(max-width:760px){
body{background:var(--bg)}
.mobile-topbar{position:sticky;top:0;z-index:40;display:flex;align-items:center;gap:12px;min-height:62px;padding:calc(8px + env(safe-area-inset-top)) 14px 8px;background:rgba(7,11,22,.96);border-bottom:1px solid rgba(255,255,255,.10);backdrop-filter:blur(14px)}
.mobile-menu-button{width:46px;height:46px;min-height:46px;padding:0;border-radius:14px;background:rgba(255,255,255,.08);display:grid;place-content:center;gap:5px;flex:0 0 auto}
.mobile-menu-button span{display:block;width:20px;height:2px;border-radius:99px;background:var(--text)}
.mobile-title{min-width:0;color:var(--text);text-decoration:none;display:flex;align-items:center;gap:10px}
.mobile-title .logo{width:38px;height:38px;border-radius:13px;flex:0 0 auto}
.mobile-title strong{font-size:15px;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nav-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.50);opacity:0;pointer-events:none;transition:.18s ease;z-index:70;display:block}
body.nav-active .nav-backdrop{opacity:1;pointer-events:auto}
.sidebar{position:fixed;top:0;left:0;z-index:80;width:min(318px,86vw);height:100dvh;padding:calc(18px + env(safe-area-inset-top)) 16px calc(18px + env(safe-area-inset-bottom));border-right:1px solid rgba(255,255,255,.14);box-shadow:24px 0 70px rgba(0,0,0,.46);transform:translateX(-105%);transition:transform .22s ease;overflow:auto}
body.nav-active .sidebar{transform:translateX(0)}
.brand{justify-content:flex-start}
.menu{display:grid;grid-template-columns:1fr;gap:6px}
.menu a,.language a{min-height:46px;padding:12px 13px;border-radius:12px;font-size:15px;text-align:left;display:flex;align-items:center}
.language{margin-top:auto}
.language div{grid-template-columns:repeat(3,1fr)}
.language a{justify-content:center;text-align:center}
.menu-logout button{width:100%;justify-content:center}
.main{padding:12px 12px calc(18px + env(safe-area-inset-bottom))}
.hero{padding:14px;border-radius:16px;gap:10px;margin-bottom:12px}
.hero .sub{display:none}
.hero-card{min-width:0;width:100%;padding:12px;border-radius:14px}
.hero-card span,.hero-card small{font-size:11px}
.hero-card strong{font-size:22px;overflow-wrap:anywhere;margin:4px 0}
h1{font-size:26px}
.eyebrow{font-size:10px;margin-bottom:5px}
.cards{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:12px}
.card,.panel{border-radius:15px;padding:14px}
.card{padding:11px 12px}
.card span,.card small{font-size:11px;line-height:1.25}
.card strong{font-size:17px;overflow-wrap:anywhere;margin-top:4px}
.toolbar-groups{gap:8px;margin-bottom:12px}
.toolbar-group{border-radius:14px;padding:10px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
.toolbar-group span{font-size:11px}
.toolbar-group button,.toolbar-row button{width:100%;min-height:40px;padding:9px 10px;border-radius:12px;font-size:13px;text-align:center;display:flex;align-items:center;justify-content:center}
.toolbar-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:12px}
.drawer-panel{width:100vw;max-width:none;padding:calc(16px + env(safe-area-inset-top)) 16px calc(18px + env(safe-area-inset-bottom));height:100dvh}
.drawer-head{position:sticky;top:calc(-16px - env(safe-area-inset-top));background:#0b1020;padding:10px 0;z-index:1}
.drawer-panel .form button{width:100%;margin-top:4px}
input,select,textarea{min-height:48px;border-radius:13px}
.month-nav{gap:8px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;margin:0 0 14px}
.month-nav a,.month-nav strong{font-size:13px;text-align:center}
.form-inline-edit{grid-template-columns:1fr}
.section-title{display:grid}
.table-wrap{overflow:visible;margin:0;padding:0}
.compact-table,.compact-table thead,.compact-table tbody,.compact-table tr,.compact-table td{display:block;width:100%}
.compact-table thead{display:none}
.compact-table tr{background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.11);border-radius:14px;margin:0 0 10px;padding:10px}
.compact-table td{border:0;padding:8px 4px;white-space:normal;font-size:14px;display:grid;grid-template-columns:minmax(92px,38%) minmax(0,1fr);gap:10px;align-items:center}
.compact-table td::before{content:attr(data-label);color:var(--muted);font-size:12px;font-weight:800}
.compact-table td:empty{display:none}
.compact-table .edit-row{background:transparent;border:0;padding:0;margin:-6px 0 10px}
.compact-table .edit-row td{display:block;padding:0}
.compact-table .edit-row td::before{display:none}
.compact-table details{background:rgba(255,255,255,.045);border-radius:12px;padding:10px}
.actions{display:flex;justify-content:flex-start}
.inline-form{display:flex;gap:6px;flex-wrap:wrap}
.inline-form input{max-width:none}
.inline-form button,.actions button{min-height:40px;padding:9px 11px}
.allocation-split{gap:12px}
.chart-box{min-height:220px}
canvas{max-height:320px}
}
