:root{--bg:#0b0f1a;--bg-2:#0d1220;--sidebar:#0f1525;--glass:#ffffff08;--glass-hover:#ffffff0e;--border:#ffffff12;--border-strong:#ffffff1f;--border-glow:#4361ee59;--text:#e2e8f0;--text-dim:#8892a4;--text-muted:#3d4a5c;--accent:#00e5a0;--accent-dim:#00e5a01a;--accent-glow:#00e5a02e;--blue:#4361ee;--blue-dim:#4361ee24;--blue-glow:#4361ee38;--warn:#f59e0b;--warn-dim:#f59e0b1f;--danger:#ef4444;--danger-dim:#ef44441a;--radius:14px;--radius-sm:9px;--sidebar-w:228px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:Barlow Condensed,sans-serif;font-size:15px;line-height:1.5}body:before{content:"";pointer-events:none;z-index:0;background-image:linear-gradient(#4361ee08 1px,#0000 1px),linear-gradient(90deg,#4361ee08 1px,#0000 1px);background-size:40px 40px;position:fixed;inset:0}.mono{font-feature-settings:"tnum" 1;font-family:IBM Plex Mono,monospace}.app{z-index:1;height:100vh;display:flex;position:relative;overflow:hidden}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--sidebar);border-right:1px solid var(--border);z-index:2;flex-direction:column;padding:18px 10px;display:flex;position:relative}.sidebar:after{content:"";background:linear-gradient(180deg, transparent, var(--blue-glow), transparent);pointer-events:none;width:1px;position:absolute;top:0;bottom:0;right:-1px}.sidebar-brand{border-bottom:1px solid var(--border);align-items:center;gap:10px;margin-bottom:10px;padding:6px 10px 18px;display:flex}.sidebar-logo{color:var(--blue);filter:drop-shadow(0 0 6px var(--blue-glow));font-size:1.25rem}.sidebar-name{letter-spacing:.06em;color:var(--text);font-family:Barlow Condensed,sans-serif;font-size:1.1rem;font-weight:700}.sidebar-nav{flex-direction:column;flex:1;gap:3px;display:flex}.sidebar-item{border-radius:var(--radius-sm);color:var(--text-dim);cursor:pointer;letter-spacing:.02em;text-align:left;background:0 0;border:1px solid #0000;align-items:center;gap:11px;width:100%;padding:10px 12px;font-family:Barlow Condensed,sans-serif;font-size:.92rem;font-weight:600;transition:all .15s;display:flex}.sidebar-item:hover{background:var(--glass-hover);color:var(--text)}.sidebar-item.active{background:var(--blue-dim);color:var(--text);border-color:#4361ee40;box-shadow:inset 0 0 20px #4361ee0d}.sidebar-item.active .sidebar-icon{color:var(--blue)}.sidebar-icon{text-align:center;flex-shrink:0;width:18px;font-size:.95rem}.sidebar-label{text-overflow:ellipsis;white-space:nowrap;font-size:.85rem;overflow:hidden}.sidebar-footer{border-top:1px solid var(--border);padding-top:12px}.sidebar-user{border-radius:var(--radius-sm);align-items:center;gap:10px;padding:8px 10px;display:flex}.sidebar-avatar{background:linear-gradient(135deg, var(--blue), #7b9ef0);color:#fff;width:30px;height:30px;box-shadow:0 0 12px var(--blue-glow);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-family:IBM Plex Mono,monospace;font-size:.68rem;font-weight:600;display:flex}.sidebar-user-name{color:var(--text);font-size:.82rem;font-weight:600;display:block}.sidebar-user-plan{color:var(--text-dim);font-size:.68rem;display:block}.main-wrap{flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden}.top-bar{border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:1;background:#0b0f1acc;flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 26px;display:flex;position:relative}.page-title{letter-spacing:.02em;color:var(--text);font-size:1.25rem;font-weight:700}.page-subtitle{color:var(--text-dim);margin-top:1px;font-size:.75rem}.main-content{flex:1;padding:22px 26px;overflow-y:auto}.main-content::-webkit-scrollbar{width:3px}.main-content::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:4px}.card{background:var(--glass);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;transition:border-color .2s,box-shadow .2s;position:relative;overflow:hidden}.card:hover{border-color:var(--border-strong)}.card-title{letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim);margin-bottom:14px;font-size:.68rem;font-weight:700}.btn{border-radius:var(--radius-sm);cursor:pointer;letter-spacing:.05em;border:none;align-items:center;gap:6px;padding:9px 18px;font-family:Barlow Condensed,sans-serif;font-size:.85rem;font-weight:700;transition:all .15s;display:inline-flex}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.38;cursor:not-allowed}.btn-blue{background:var(--blue);color:#fff;box-shadow:0 4px 14px #4361ee4d}.btn-blue:hover:not(:disabled){background:#5472f0;box-shadow:0 4px 20px #4361ee73}.btn-accent{background:var(--accent);color:#000;box-shadow:0 4px 14px var(--accent-glow);font-weight:700}.btn-accent:hover:not(:disabled){opacity:.88}.btn-ghost{background:var(--glass);border:1px solid var(--border-strong);color:var(--text-dim);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.btn-ghost:hover:not(:disabled){color:var(--text);background:var(--glass-hover)}.btn-danger{background:var(--danger-dim);color:var(--danger);border:1px solid #0000;padding:5px 10px;font-size:.75rem}.btn-danger:hover:not(:disabled){background:var(--danger);color:#fff}.form-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}@media (width<=640px){.form-grid{grid-template-columns:1fr}}.form-field{flex-direction:column;gap:6px;display:flex}.form-field.full-width{grid-column:1/-1}.label{letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);font-size:.68rem;font-weight:700}.input,.select{border:1px solid var(--border-strong);border-radius:var(--radius-sm);color:var(--text);appearance:none;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff0a;outline:none;width:100%;padding:10px 13px;font-family:IBM Plex Mono,monospace;font-size:.88rem;transition:border-color .15s,box-shadow .15s}.input:focus,.select:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-dim)}.input::placeholder{color:var(--text-muted)}.select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238892a4' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:34px}.select option{color:var(--text);background:#131c2e}.error-banner{background:var(--danger-dim);border-radius:var(--radius-sm);color:var(--danger);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid #ef444440;margin-bottom:16px;padding:10px 14px;font-family:IBM Plex Mono,monospace;font-size:.78rem}@keyframes spin{to{transform:rotate(360deg)}}.spinner{border:2px solid var(--border-strong);border-top-color:var(--accent);border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin;display:inline-block}.spinner-center{justify-content:center;align-items:center;padding:60px;display:flex}@keyframes popIn{0%{opacity:0;transform:scale(.8)translateY(20px)}65%{opacity:1;transform:scale(1.04)translateY(0)}to{opacity:1;transform:scale(1)translateY(0)}}@keyframes fadeOut{to{opacity:0;pointer-events:none}}.streak-overlay{z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000a6;justify-content:center;align-items:center;animation:.45s cubic-bezier(.34,1.56,.64,1) forwards popIn;display:flex;position:fixed;inset:0}.streak-overlay.fading{animation:.35s forwards fadeOut}.streak-card{border:1px solid var(--border-strong);text-align:center;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#0f1525eb;border-radius:20px;width:90%;max-width:380px;padding:44px 52px;position:relative;overflow:hidden;box-shadow:0 0 0 1px #4361ee33,0 0 80px #00e5a01a,0 30px 60px #00000080}.streak-card:before{content:"";background:linear-gradient(90deg, transparent, var(--accent), transparent);height:2px;position:absolute;top:0;left:0;right:0}.streak-check{color:var(--accent);filter:drop-shadow(0 0 12px var(--accent-glow));margin-bottom:14px;font-size:2.8rem;display:block}.streak-title{letter-spacing:.04em;color:var(--text);margin-bottom:10px;font-family:Barlow Condensed,sans-serif;font-size:1.5rem;font-weight:700}.streak-msg-text{color:var(--text-dim);font-size:.9rem;line-height:1.6}.table-wrap{overflow-x:auto}.history-table{border-collapse:collapse;width:100%;font-size:.875rem}.history-table th{letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;padding:10px 14px;font-size:.62rem;font-weight:700}.history-table td{border-bottom:1px solid var(--border);vertical-align:middle;color:var(--text-dim);padding:13px 14px}.history-table td.strong{color:var(--text)}.history-table tr:last-child td{border-bottom:none}.history-table tbody tr{transition:background .12s}.history-table tbody tr:hover td{background:#ffffff06}.history-table .mono{font-size:.82rem}.badge{letter-spacing:.06em;text-transform:uppercase;border-radius:20px;padding:3px 10px;font-size:.66rem;font-weight:700;display:inline-block}.badge-ja{background:var(--accent-dim);color:var(--accent);border:1px solid #00e5a033}.badge-deels{background:var(--warn-dim);color:var(--warn);border:1px solid #f59e0b33}.badge-nee{background:var(--danger-dim);color:var(--danger);border:1px solid #ef444433}.gauge-stat{border:1px solid var(--border);border-radius:var(--radius-sm);background:#ffffff08;flex-direction:column;flex:1;align-items:center;gap:4px;padding:10px 12px;display:flex}.gauge-stat-label{letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);font-size:.62rem;font-weight:700}.gauge-stat-value{font-family:IBM Plex Mono,monospace;font-size:1.3rem;font-weight:600}.gauge-stat-value.accent{color:var(--accent)}.gauge-stat-value.danger{color:var(--danger)}.kpi-row{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:16px;display:grid}.kpi-card{background:var(--glass);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;transition:border-color .2s}.kpi-card:hover{border-color:var(--border-strong)}.kpi-label{letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);margin-bottom:8px;font-size:.62rem;font-weight:700}.kpi-value{color:var(--text);font-family:IBM Plex Mono,monospace;font-size:1.8rem;font-weight:600;line-height:1}.streak-banner{border-radius:var(--radius-sm);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);align-items:center;gap:8px;margin-bottom:16px;padding:11px 16px;font-size:.88rem;display:flex}.streak-banner.success{background:var(--accent-dim);color:var(--accent);border:1px solid #00e5a02e}.streak-banner.warn{background:var(--warn-dim);color:var(--warn);border:1px solid #f59e0b2e}.week-grid{grid-template-columns:repeat(7,1fr);gap:6px;display:grid}.week-day{aspect-ratio:1;border-radius:var(--radius-sm);border:1px solid var(--border);background:#ffffff05;flex-direction:column;justify-content:center;align-items:center;gap:4px;transition:all .2s;display:flex}.week-day.done{background:var(--accent-dim);border-color:#00e5a040;box-shadow:0 0 14px #00e5a014}.week-day-label{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);font-size:.55rem;font-weight:700}.week-day.done .week-day-label{color:var(--accent)}.week-day-dot{background:var(--border-strong);border-radius:50%;width:6px;height:6px}.week-day.done .week-day-dot{background:var(--accent);box-shadow:0 0 6px var(--accent)}.chart-wrapper{width:100%;height:200px}.empty-state{text-align:center;color:var(--text-muted);padding:56px 20px;font-size:.9rem}@media (width<=900px){div[style*="280px"]{grid-template-columns:1fr!important}div[style*="280px"]>div:last-child{display:none}}@media (width<=700px){.sidebar{display:none}.main-content{padding:14px}.kpi-row{grid-template-columns:1fr 1fr}}.trade-summary{border:1px solid var(--border);background:#ffffff05;border-radius:8px;flex-wrap:wrap;align-items:center;gap:18px;margin-top:12px;padding:10px 14px;font-size:.84rem;display:flex}.trade-summary b{font-family:IBM Plex Mono,monospace;font-weight:600}.week-progress{margin:14px 0 6px}.week-progress-label{letter-spacing:1.2px;color:var(--text-muted);text-transform:uppercase;justify-content:space-between;margin-bottom:6px;font-size:.72rem;display:flex}.week-progress-track{background:#ffffff0d;border-radius:2px;height:4px;overflow:hidden}.week-progress-fill{border-radius:2px;height:100%;transition:width .5s cubic-bezier(.4,0,.2,1)}.quick-capture-fab{background:linear-gradient(135deg, var(--blue), #6c83f0);color:#fff;cursor:pointer;z-index:50;border:none;border-radius:50%;width:56px;height:56px;font-size:1.7rem;font-weight:300;transition:transform .18s,box-shadow .18s;position:fixed;bottom:28px;right:28px;box-shadow:0 8px 24px #4361ee73,0 2px 6px #0000004d}.quick-capture-fab:hover{transform:translateY(-2px)scale(1.04);box-shadow:0 12px 32px #4361ee8c,0 4px 8px #00000059}.quick-capture-fab:active{transform:translateY(0)scale(.98)}.modal-backdrop{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:100;background:#050810b3;justify-content:center;align-items:center;padding:20px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#141a2deb;border:1px solid #ffffff14;border-radius:14px;width:100%;max-width:560px;max-height:86vh;padding:22px 24px;animation:.22s cubic-bezier(.4,1.5,.5,1) popIn;overflow-y:auto;box-shadow:0 24px 60px #0009}.modal-stats{grid-template-columns:repeat(4,1fr);gap:10px;margin:16px 0;display:grid}.modal-stat{border:1px solid var(--border);background:#ffffff06;border-radius:8px;padding:10px 12px}.modal-stat-label{letter-spacing:1.1px;color:var(--text-muted);text-transform:uppercase;margin-bottom:4px;font-size:.66rem}.modal-stat-value{font-size:1rem;font-weight:600}.modal-section{margin-top:14px}.modal-section-title{letter-spacing:1.2px;color:var(--text-muted);text-transform:uppercase;margin-bottom:6px;font-size:.7rem}@media (width<=600px){.modal-stats{grid-template-columns:repeat(2,1fr)}.quick-capture-fab{width:50px;height:50px;bottom:18px;right:18px}}
