:root{--bg:#0b1118;--surface:#151f2e;--surface-hover:#202c3d;--border:#29374a;--text:#e8edf4;--text-muted:#8b9cb3;--primary:#3b82f6;--primary-hover:#2563eb;--success:#22c55e;--danger:#ef4444;--warning:#f59e0b;--radius:14px;--shadow:0 12px 40px #00000047}*{box-sizing:border-box;margin:0;padding:0}body{background:radial-gradient(circle at top left, #3b82f624, transparent 32rem), radial-gradient(circle at top right, #22c55e14, transparent 28rem), var(--bg);color:var(--text);min-height:100vh;font-family:Segoe UI,system-ui,-apple-system,sans-serif;line-height:1.5}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}.app{flex-direction:column;min-height:100vh;display:flex}.header{border-bottom:1px solid var(--border);z-index:100;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#0f1620e6;justify-content:space-between;align-items:center;gap:1rem;padding:.85rem clamp(1rem,4vw,2rem);display:flex;position:sticky;top:0}.logo{align-items:center;min-width:0;display:inline-flex}.logo-image{object-fit:contain;width:auto;max-width:min(180px,38vw);height:38px;display:block}.primary-nav{scrollbar-width:none;align-items:center;gap:.5rem;display:flex;overflow-x:auto}.primary-nav::-webkit-scrollbar{display:none}.nav-link{color:var(--text-muted);white-space:nowrap;border-radius:999px;padding:.5rem .85rem;font-size:.92rem;font-weight:600;transition:background .2s,color .2s,transform .2s}.nav-link:hover{background:var(--surface-hover);color:var(--text)}.btn-primary{background:var(--primary);color:#fff!important}.btn-primary:hover{background:var(--primary-hover)}.main{flex:1;width:100%;max-width:1400px;margin:0 auto;padding:clamp(1rem,4vw,2rem)}.auth-page{place-items:center;min-height:100vh;padding:1.5rem;display:grid}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:min(100%,420px);box-shadow:var(--shadow);text-align:center;padding:clamp(1.5rem,5vw,2rem)}.auth-logo{width:auto;height:52px;margin-bottom:1.25rem}.auth-card h1{margin-bottom:.5rem;font-size:clamp(1.4rem,5vw,1.8rem)}.auth-card p{color:var(--text-muted);margin-bottom:1.25rem}.auth-card input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);margin-bottom:1rem;padding:.75rem .9rem}.auth-card input:focus{border-color:var(--primary);outline:none}.auth-card .btn{justify-content:center;width:100%}.page-title{letter-spacing:-.03em;margin-bottom:clamp(1rem,3vw,1.5rem);font-size:clamp(1.45rem,5vw,1.85rem);font-weight:600}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:clamp(1rem,3vw,1.5rem)}.summary-grid{grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:.85rem;margin-bottom:clamp(1rem,4vw,2rem);display:grid}.summary-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;box-shadow:0 8px 28px #0000002e}.summary-card .label{color:var(--text-muted);margin-bottom:.25rem;font-size:.875rem}.summary-card .value{letter-spacing:-.03em;font-size:clamp(1.15rem,5vw,1.5rem);font-weight:600}.summary-card .value.positive{color:var(--success)}.summary-card .value.negative{color:var(--danger)}.toolbar{flex-wrap:wrap;gap:.75rem;margin-bottom:1rem;display:flex}.search-input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);min-width:min(100%,220px);color:var(--text);flex:1;padding:.7rem .9rem}.search-input:focus{border-color:var(--primary);outline:none}.asset-list{flex-direction:column;gap:.85rem;display:flex}.asset-card{cursor:pointer;transition:border-color .15s,box-shadow .15s,transform .15s}.asset-card:hover{border-color:var(--primary);box-shadow:var(--shadow);transform:translateY(-1px)}.asset-card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:.9rem;padding-bottom:.9rem;display:flex}.asset-metrics-grid{grid-template-columns:repeat(auto-fill,minmax(124px,1fr));gap:.75rem;display:grid}.metric-cell{min-width:0}.metric-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;margin-bottom:.2rem;font-size:.7rem}.metric-value{overflow-wrap:anywhere;font-size:.92rem;font-weight:600}.metric-value.positive{color:var(--success)}.metric-value.negative{color:var(--danger)}.allocation-panel{margin-bottom:clamp(1rem,4vw,2rem)}.allocation-layout{grid-template-columns:1fr 1fr;align-items:center;gap:1.5rem;display:grid}@media (width<=768px){.allocation-layout{grid-template-columns:1fr}}.allocation-breakdown{flex-direction:column;gap:.75rem;display:flex}.allocation-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:1rem;padding:.5rem 0;display:flex}.allocation-row:last-child{border-bottom:none}.allocation-row-label{align-items:center;gap:.5rem;font-weight:500;display:flex}.allocation-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.allocation-row-value{text-align:right;white-space:nowrap}.allocation-trend{border-top:1px solid var(--border);margin-top:1.5rem;padding-top:1.5rem}.table-container{overflow-x:auto}table{border-collapse:collapse;width:100%}th,td{text-align:left;border-bottom:1px solid var(--border);padding:.8rem .9rem}th{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:.75rem;font-weight:600}tbody tr{transition:background .15s}tbody tr:hover{background:var(--surface-hover)}tbody tr.clickable{cursor:pointer}.profit-positive{color:var(--success);font-weight:600}.profit-negative{color:var(--danger);font-weight:600}.btn{border-radius:var(--radius);cursor:pointer;border:none;justify-content:center;align-items:center;gap:.5rem;padding:.65rem 1rem;font-weight:500;transition:background .2s,opacity .2s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary-solid{background:var(--primary);color:#fff}.btn-primary-solid:hover:not(:disabled){background:var(--primary-hover)}.btn-secondary{background:var(--surface-hover);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--border)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){opacity:.9}.form-group{margin-bottom:1rem}.form-group label{color:var(--text-muted);margin-bottom:.375rem;font-size:.875rem;font-weight:500;display:block}.form-group input,.form-group select,.form-group textarea{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);padding:.7rem .85rem}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);outline:none}.form-row{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.85rem;display:grid}.search-results{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);z-index:50;max-height:240px;margin-top:.25rem;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.search-result-item{cursor:pointer;border-bottom:1px solid var(--border);padding:.75rem 1rem}.search-result-item:hover{background:var(--surface-hover)}.search-result-item:last-child{border-bottom:none}.search-wrapper{position:relative}.selected-fund{background:var(--surface-hover);border:1px solid var(--primary);border-radius:var(--radius);margin-bottom:1.5rem;padding:1rem}.selected-fund .fund-name{margin-bottom:.25rem;font-weight:600}.selected-fund .fund-meta{color:var(--text-muted);font-size:.875rem}.detail-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.9rem;margin-bottom:2rem;display:grid}.detail-item .label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:.25rem;font-size:.75rem}.detail-item .value{font-size:1.125rem;font-weight:500}.chart-container{margin:1.25rem 0;padding:1rem}.chart-title{margin-bottom:1rem;font-size:1.125rem;font-weight:600}.actions{flex-wrap:wrap;gap:.75rem;margin-top:1.5rem;display:flex}.loading,.error,.empty{text-align:center;color:var(--text-muted);padding:clamp(1.5rem,8vw,3rem)}.error{color:var(--danger)}.badge{background:var(--surface-hover);color:var(--text-muted);letter-spacing:.02em;border-radius:999px;padding:.22rem .55rem;font-size:.7rem;font-weight:700;display:inline-block}.back-link{color:var(--text-muted);align-items:center;gap:.5rem;margin-bottom:1rem;font-size:.875rem;display:inline-flex}.back-link:hover{color:var(--primary)}.tabs{scrollbar-width:none;flex-wrap:nowrap;gap:.45rem;margin-inline:-.25rem;padding:.25rem;display:flex;overflow-x:auto}.tabs::-webkit-scrollbar{display:none}.tab{border:1px solid var(--border);background:var(--surface);color:var(--text-muted);cursor:pointer;white-space:nowrap;border-radius:999px;align-items:center;gap:.375rem;padding:.5rem .8rem;font-size:.84rem;transition:background .2s,color .2s,border-color .2s;display:inline-flex}.tab:hover{background:var(--surface-hover);color:var(--text)}.tab.active{background:var(--primary);border-color:var(--primary);color:#fff}.tab-count{background:#fff3;border-radius:999px;padding:.125rem .375rem;font-size:.75rem}.tab.active .tab-count{background:#ffffff40}.dashboard-controls{justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:1rem;display:flex;position:relative}.dashboard-controls .tabs{flex:1}.filter-menu{flex-shrink:0;padding-top:.25rem;position:relative}.filter-trigger{white-space:nowrap;border-radius:999px;padding:.5rem .8rem;font-size:.84rem}.filter-popover{z-index:80;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:min(320px,100vw - 2rem);box-shadow:var(--shadow);padding:.85rem;position:absolute;top:calc(100% + .45rem);right:0}.filter-popover-header{color:var(--text-muted);margin-bottom:.7rem;font-size:.78rem}.filter-popover-header strong{color:var(--text);margin-bottom:.1rem;font-size:.92rem;display:block}.filter-options{gap:.4rem;max-height:320px;display:grid;overflow-y:auto}.filter-option{background:var(--bg);border:1px solid var(--border);cursor:pointer;border-radius:10px;align-items:flex-start;gap:.55rem;padding:.55rem;display:flex}.filter-option:hover{background:var(--surface-hover)}.filter-option input{accent-color:var(--primary);margin-top:.15rem}.filter-option span{gap:.1rem;display:grid}.filter-option strong{font-size:.84rem}.filter-option small{color:var(--text-muted);font-size:.72rem}.filter-actions{flex-wrap:wrap;justify-content:flex-end;gap:.45rem;margin-top:.75rem;display:flex}.asset-type-grid{grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:.85rem;display:grid}.asset-type-card{text-align:left;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;color:var(--text);padding:1rem;transition:border-color .2s,background .2s,transform .15s}.asset-type-card:hover{border-color:var(--primary);background:var(--surface-hover);transform:translateY(-2px)}.asset-type-label{margin-bottom:.375rem;font-weight:600}.asset-type-desc{color:var(--text-muted);font-size:.8rem;line-height:1.4}.timeline-header{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.timeline-header .page-title{margin-bottom:0}.section-title{margin-bottom:1rem;font-size:1.125rem}.subsection-title{color:var(--text-muted);margin:1.25rem 0 .75rem;font-size:.95rem}.summary-subtext{color:var(--text-muted);margin-top:.25rem;font-size:.85rem}.timeline-chart,.timeline-fire-bar{margin-bottom:1.25rem}.timeline-fire-bar-header{color:var(--text-muted);justify-content:space-between;gap:1rem;margin-bottom:.75rem;font-size:.9rem;display:flex}.progress-track{background:var(--bg);border-radius:999px;height:10px;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--primary), var(--success));border-radius:999px;height:100%;transition:width .3s}.timeline-panels{grid-template-columns:minmax(280px,360px) 1fr;align-items:start;gap:1rem;display:grid}.timeline-form{flex-direction:column;gap:1rem;display:flex}.timeline-form label{color:var(--text-muted);flex-direction:column;gap:.375rem;font-size:.875rem;font-weight:500;display:flex}.form-input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);padding:.7rem .85rem}.form-input:focus{border-color:var(--primary);outline:none}.timeline-form-actions{gap:.75rem;display:flex}.timeline-fire-form{border-top:1px solid var(--border);margin-top:1.5rem;padding-top:1.5rem}.table-subtext{color:var(--text-muted);margin-top:.125rem;font-size:.75rem}.table-actions{white-space:nowrap;gap:.5rem;display:flex}.btn-sm{padding:.375rem .625rem;font-size:.8rem}.asset-title-row{align-items:center;gap:.5rem;min-width:0;margin-bottom:.25rem;display:flex}.asset-title-row strong{overflow-wrap:anywhere;min-width:0}.asset-subtitle{color:var(--text-muted);overflow-wrap:anywhere;font-size:.85rem}td.positive{color:var(--success)}td.negative{color:var(--danger)}.chart-tooltip{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:.75rem 1rem}.chart-tooltip-title{margin-bottom:.25rem;font-weight:600}.chart-tooltip-muted{color:var(--text-muted);margin-top:.25rem;font-size:.85rem}@media (width<=768px){.timeline-header{flex-direction:column;align-items:flex-start}.timeline-panels{grid-template-columns:1fr}.main{padding:1rem}.header{align-items:center;padding:.7rem .85rem}.primary-nav{flex:1;justify-content:flex-end}th,td{padding:.625rem .5rem;font-size:.875rem}}@media (width<=560px){body{line-height:1.4}.main{padding:.85rem}.header{gap:.65rem}.logo-image{max-width:30vw;height:32px}.nav-link{padding:.45rem .65rem;font-size:.82rem}.nav-link.btn-primary{padding-inline:.7rem}.page-title{margin-bottom:.85rem}.summary-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.65rem}.summary-card{padding:.8rem}.summary-card .label{font-size:.74rem}.summary-card .value{font-size:1rem}.card{padding:.9rem}.asset-card-header{flex-direction:column;align-items:stretch}.asset-card-header .btn{align-self:flex-start;padding:.42rem .75rem}.asset-title-row{flex-wrap:wrap;align-items:flex-start}.asset-metrics-grid,.detail-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:.7rem}.metric-label,.detail-item .label{font-size:.68rem}.metric-value,.detail-item .value{font-size:.88rem}.toolbar{grid-template-columns:1fr auto;gap:.55rem;display:grid}.toolbar .search-input{grid-column:1/-1}.toolbar .btn{width:100%;padding:.58rem .8rem}.tabs{margin-bottom:.85rem}.dashboard-controls{align-items:stretch;gap:.5rem}.dashboard-controls .tabs{margin-bottom:0}.filter-menu{padding-top:.25rem}.tab{padding:.45rem .7rem;font-size:.78rem}.filter-trigger{padding:.45rem .65rem;font-size:.78rem}.filter-popover{width:min(300px,100vw - 1rem);right:-.1rem}.allocation-layout{gap:.75rem}.allocation-row{align-items:flex-start;padding:.45rem 0}.allocation-row-value span{font-size:.78rem;display:block;margin-left:0!important}.allocation-pie{margin-inline:-.5rem}.chart-container,.timeline-chart{margin-inline:-.35rem}.actions{grid-template-columns:1fr;display:grid}.actions .btn{width:100%}.asset-type-grid,.form-row,.timeline-panels{grid-template-columns:1fr}.timeline-fire-bar-header{font-size:.8rem}.table-container{margin-inline:-.9rem;padding-inline:.9rem}}@media (width<=380px){.summary-grid,.asset-metrics-grid,.detail-grid{grid-template-columns:1fr}.nav-link{font-size:.78rem}}
