*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}:root{--r-sm:8px;--r:12px;--r-lg:16px;--sans:'Inter',-apple-system,'Segoe UI',system-ui,sans-serif;--mono:'JetBrains Mono',ui-monospace,'Cascadia Code',Consolas,monospace;--ease:cubic-bezier(.4,0,.2,1);--up:#3fbf7f;--down:#e0625e;--boat-img-sm:url("assets/boat-sm.png");--waves-img:url("assets/waves.png");--boat-img:url("assets/boat.png")}:root[data-theme="dark"]{--bg:#0a0a0b;--bg-2:#0e0e10;--surface:#141416;--surface-2:#1a1a1d;--surface-3:#202024;--border:rgba(255,255,255,.09);--border-2:rgba(255,255,255,.16);--fg:#f4f4f5;--fg-2:#a1a1a6;--fg-3:#6b6b70;--hover:rgba(255,255,255,.045);--active:rgba(255,255,255,.08);--hatch:rgba(255,255,255,.55);--grid:rgba(255,255,255,.06);--grid-line:rgba(255,255,255,.028);--cell-lit:rgba(255,255,255,.14);--cell-lit2:rgba(255,255,255,.055);--cell-glow:rgba(255,255,255,.10);--shadow:0 12px 40px -12px rgba(0,0,0,.7)}:root[data-theme="light"]{--bg:#f6f6f4;--bg-2:#fbfbfa;--surface:#ffffff;--surface-2:#f3f3f1;--surface-3:#eaeae7;--border:rgba(0,0,0,.10);--border-2:rgba(0,0,0,.20);--fg:#101010;--fg-2:#555558;--fg-3:#8a8a8e;--hover:rgba(0,0,0,.035);--active:rgba(0,0,0,.07);--hatch:rgba(0,0,0,.5);--grid:rgba(0,0,0,.07);--grid-line:rgba(0,0,0,.025);--cell-lit:rgba(0,0,0,.08);--cell-lit2:rgba(0,0,0,.035);--cell-glow:rgba(0,0,0,.05);--shadow:0 12px 40px -16px rgba(0,0,0,.25)}html,body{height:100%}body{font-family:var(--sans);background:var(--bg);color:var(--fg);font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased;display:grid;grid-template-columns:248px 1fr;min-height:100vh}.fxgrid{position:fixed;inset:0;z-index:-1;display:grid;overflow:hidden;pointer-events:none}.fxgrid .fx-cell{border-right:1px solid var(--grid-line);border-bottom:1px solid var(--grid-line);transition:background .9s var(--ease),box-shadow .9s var(--ease)}.fxgrid .fx-cell.on{background:var(--cell-lit);box-shadow:inset 0 0 18px var(--cell-glow);transition:none}.fxgrid .fx-cell.on2{background:var(--cell-lit2);transition:none}.mono{font-family:var(--mono);font-variant-numeric:tabular-nums}.num{font-family:var(--mono);font-variant-numeric:tabular-nums;letter-spacing:-.01em}button{font-family:inherit;cursor:pointer;color:inherit;background:none;border:none}input,select,textarea{font-family:inherit;font-size:14px;color:var(--fg)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:20px;border:3px solid transparent;background-clip:content-box}::-webkit-scrollbar-track{background:transparent}.sidebar{background:var(--bg-2);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:22px 16px;position:sticky;top:0;height:100vh}.brand{display:flex;align-items:center;gap:11px;padding:4px 8px 22px}.brand .mark{width:58px;height:52px;display:grid;place-items:center;flex:none;color:var(--fg)}.brand h1{font-size:15px;font-weight:700;letter-spacing:.18em}.brand small{display:block;font-size:9.5px;letter-spacing:.32em;color:var(--fg-3);font-weight:500;margin-top:1px}.logo-img{width:58px;height:52px;background:var(--boat-img) no-repeat center/contain}[data-theme="dark"] .logo-img{filter:invert(1)}.nav{display:flex;flex-direction:column;gap:3px;position:relative}.nav-ind{position:absolute;left:0;width:100%;border-radius:var(--r-sm);background:var(--active);z-index:0;opacity:0;pointer-events:none;transform:translateY(0);transition:transform .34s var(--ease),height .34s var(--ease),opacity .2s var(--ease)}.nav-label{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--fg-3);padding:0 10px 8px;font-weight:600}.nav button{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:var(--r-sm);color:var(--fg-2);font-size:13.5px;font-weight:500;text-align:left;width:100%;position:relative;z-index:1;transition:color .18s var(--ease)}.nav button:not(.active):hover{background:var(--hover);color:var(--fg)}.nav button.active{color:var(--fg)}.nav button svg{width:17px;height:17px;flex:none;opacity:.85;transition:transform .18s var(--ease)}.nav button.active svg{opacity:1;animation:navPop .34s var(--ease)}.nav button:not(.active):hover svg{transform:translateX(2px)}@keyframes navPop{0%{transform:scale(.65)}55%{transform:scale(1.2)}100%{transform:scale(1)}}.sidebar .spacer{flex:1}.side-foot{display:flex;flex-direction:column;gap:6px;border-top:1px solid var(--border);padding-top:14px}.side-foot .row{display:flex;gap:6px}.foot-hint{font-size:10px;line-height:1.4;color:var(--fg-3);padding:1px 2px 3px}.ghost{display:flex;align-items:center;justify-content:center;gap:7px;flex:1;padding:8px 10px;border:1px solid var(--border);border-radius:var(--r-sm);color:var(--fg-2);font-size:12px;font-weight:500;transition:.15s var(--ease)}.ghost:hover{background:var(--hover);color:var(--fg);border-color:var(--border-2)}.ghost svg{width:15px;height:15px}.main{display:flex;flex-direction:column;min-width:0}.topbar{display:flex;align-items:center;gap:16px;padding:20px 30px;border-bottom:1px solid var(--border);position:sticky;top:0;background:color-mix(in srgb,var(--bg) 88%,transparent);backdrop-filter:blur(12px);z-index:20}.topbar .title{flex:none;min-width:0}.topbar h2{font-size:19px;font-weight:600;letter-spacing:-.01em}.topbar p{font-size:12.5px;color:var(--fg-3);margin-top:2px}.sail-lane{flex:1 1 120px;min-width:90px;align-self:stretch;position:relative;overflow:hidden;pointer-events:none}.sail-waves{position:absolute;left:0;right:0;bottom:0;height:22px;background:var(--waves-img) repeat-x left bottom;background-size:auto 100%;opacity:1}.sail-boat{position:absolute;left:0;bottom:8px;width:46px;height:40px;z-index:2;will-change:transform;animation:sailAcross var(--sail-dur,22s) linear infinite}.sail-img{display:block;width:100%;height:100%;background:var(--boat-img-sm) no-repeat center bottom/contain;transform-origin:50% 92%;animation:sailBob 3.2s ease-in-out infinite}[data-theme="dark"] .sail-img,[data-theme="dark"] .sail-waves{filter:invert(1) contrast(1.4) brightness(1.15)}[data-theme="light"] .sail-img,[data-theme="light"] .sail-waves{filter:contrast(1.3)}@keyframes sailAcross{0%{transform:translateX(-52px)}100%{transform:translateX(var(--lane-w,220px))}}@keyframes sailBob{0%,100%{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-2px) rotate(2deg)}}@media (prefers-reduced-motion:reduce){.sail-boat,.sail-img{animation:none}}.controls{display:flex;align-items:center;gap:9px;flex-wrap:wrap}.field{position:relative;display:flex;align-items:center}.field svg{position:absolute;left:11px;top:50%;transform:translateY(-50%);width:15px;height:15px;color:var(--fg-3);pointer-events:none}.field input,.field select,.sel{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);padding:8px 12px;color:var(--fg);font-size:13px;outline:none;transition:border .15s var(--ease)}.field input{padding-left:32px;width:170px}.field input:focus,.field select:focus,.sel:focus{border-color:var(--border-2)}.sel{cursor:pointer;-webkit-appearance:none;appearance:none;padding-right:30px;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2.5'><path d='M6 9l6 6 6-6'/></svg>");background-repeat:no-repeat;background-position:right 10px center}.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 15px;border-radius:var(--r-sm);font-size:13px;font-weight:600;transition:.15s var(--ease);white-space:nowrap}.btn-primary{background:var(--fg);color:var(--bg)}.btn-primary:hover{opacity:.88}.btn svg{width:15px;height:15px}.dd{position:relative;display:inline-block}.dd-btn{display:inline-flex;align-items:center;gap:9px;justify-content:space-between;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);padding:8px 12px;color:var(--fg);font-size:13px;cursor:pointer;white-space:nowrap;transition:border-color .15s var(--ease),background .15s var(--ease)}.dd-btn:hover{border-color:var(--border-2)}.dd.open .dd-btn{border-color:var(--border-2);background:var(--surface-2)}.dd-btn svg{width:13px;height:13px;color:var(--fg-3);flex:none;transition:transform .2s var(--ease)}.dd.open .dd-btn svg{transform:rotate(180deg)}.dd-menu{position:absolute;top:calc(100% + 6px);left:0;min-width:100%;background:var(--surface-2);border:1px solid var(--border-2);border-radius:11px;padding:5px;box-shadow:var(--shadow);z-index:60;display:none;flex-direction:column;gap:1px}.dd.open .dd-menu{display:flex;animation:ddin .14s var(--ease)}@keyframes ddin{from{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:none}}.dd-opt{display:flex;align-items:center;justify-content:space-between;gap:22px;padding:8px 10px;border-radius:7px;font-size:13px;color:var(--fg-2);text-align:left;white-space:nowrap;transition:background .12s var(--ease),color .12s var(--ease)}.dd-opt:hover{background:var(--hover);color:var(--fg)}.dd-opt.sel{color:var(--fg);font-weight:500}.dd-opt svg{width:14px;height:14px;flex:none;opacity:0;color:var(--fg)}.dd-opt.sel svg{opacity:1}.dd-lab.ph{color:var(--fg-3)}.dtp .dd-btn svg{transform:none!important;width:14px;height:14px}.dtp-menu{padding:13px;min-width:266px;display:none}.dtp.open .dtp-menu,.dd.open .dtp-menu{display:block}.dtp-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:9px}.dtp-title{font-size:13px;font-weight:600;letter-spacing:.01em}.dtp-nav{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border-radius:7px;color:var(--fg-2);transition:background .12s var(--ease),color .12s var(--ease)}.dtp-nav:hover{background:var(--hover);color:var(--fg)}.dtp-nav svg{width:15px;height:15px}.dtp-wd{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:3px}.dtp-wd span{text-align:center;font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--fg-3);font-weight:600;padding:3px 0}.dtp-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.dtp-day{height:32px;border-radius:7px;font-size:12.5px;color:var(--fg-2);font-variant-numeric:tabular-nums;transition:background .12s var(--ease),color .12s var(--ease)}.dtp-day:hover:not(.empty){background:var(--hover);color:var(--fg)}.dtp-day.empty{visibility:hidden}.dtp-day.today{box-shadow:inset 0 0 0 1px var(--border-2)}.dtp-day.sel{background:var(--fg);color:var(--bg);font-weight:600}.dtp-time{display:flex;align-items:center;gap:7px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}.dtp-tlab{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--fg-3);font-weight:600;margin-right:auto}.dtp-time input{width:46px;text-align:center;background:var(--surface);border:1px solid var(--border);border-radius:7px;padding:6px 4px;color:var(--fg);font-size:13px;font-variant-numeric:tabular-nums}.dtp-time input:focus{border-color:var(--border-2);outline:none}.dtp-time input::-webkit-outer-spin-button,.dtp-time input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.dtp-time input{-moz-appearance:textfield}input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}.dtp-colon{color:var(--fg-3);font-weight:600}.dtp-foot{display:flex;gap:6px;margin-top:12px}.dtp-foot button{flex:1;padding:7px 0;border-radius:7px;font-size:12px;font-weight:600;border:1px solid var(--border);color:var(--fg-2);transition:.12s var(--ease)}.dtp-foot button:hover{border-color:var(--border-2);color:var(--fg)}.dtp-done{background:var(--fg);color:var(--bg);border-color:var(--fg)}.dtp-done:hover{opacity:.88;color:var(--bg)}.period-menu{min-width:252px;max-height:min(78vh,620px);overflow-y:auto}.period-menu .dd-opt.pr-toggle{margin-top:4px;padding-top:11px;border-top:1px solid var(--border);color:var(--fg)}.period-menu .dd-opt.pr-toggle svg{opacity:.65;transition:transform .2s var(--ease)}.period-menu .dd-opt.pr-toggle.on svg{transform:rotate(180deg);opacity:1}.pr-custom{display:none;padding:10px 4px 2px}.pr-custom.show{display:block;animation:ddin .14s var(--ease)}.pr-fields{display:flex;gap:8px;margin-bottom:11px}.pr-f{flex:1;display:flex;flex-direction:column;gap:4px}.pr-f span{font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--fg-3);font-weight:600;padding-left:2px}.pr-in{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:7px;padding:7px 8px;color:var(--fg);font-size:12px;font-family:var(--mono);outline:none;transition:border .15s var(--ease)}.pr-in:focus{border-color:var(--border-2)}.pr-custom .dtp-day.in-range{background:color-mix(in srgb,var(--fg) 12%,transparent);color:var(--fg);border-radius:0}.pr-foot{display:flex;gap:6px;margin-top:12px}.pr-foot button{flex:1;padding:7px 0;border-radius:7px;font-size:12px;font-weight:600;border:1px solid var(--border);color:var(--fg-2);transition:.12s var(--ease)}.pr-foot button:hover{border-color:var(--border-2);color:var(--fg)}.pr-apply{background:var(--fg);color:var(--bg);border-color:var(--fg)}.pr-apply:hover{opacity:.88;color:var(--bg)}.content{padding:26px 30px 60px;overflow-x:hidden;position:relative;touch-action:pan-y}.content.dragging .view.active{transition:none;animation:none}.view{display:none}.view.active{display:block;will-change:transform,opacity}.view.from-right{animation:vIn-r .3s var(--ease)}.view.from-left{animation:vIn-l .3s var(--ease)}@keyframes vIn-r{from{opacity:0;transform:translate3d(18px,0,0)}to{opacity:1;transform:translate3d(0,0,0)}}@keyframes vIn-l{from{opacity:0;transform:translate3d(-18px,0,0)}to{opacity:1;transform:translate3d(0,0,0)}}@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r)}.card-pad{padding:20px 22px}.card-h{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.card-h h3{font-size:13px;font-weight:600;letter-spacing:.02em}.card-h .sub{font-size:11px;color:var(--fg-3)}.grid{display:grid;gap:16px}.kpis{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:16px}.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:17px 18px}.kpi .lab{font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--fg-3);font-weight:600;display:flex;align-items:center;gap:6px}.kpi .val{font-size:27px;font-weight:600;margin-top:9px;letter-spacing:-.02em;font-family:var(--mono);font-variant-numeric:tabular-nums}.kpi .meta{font-size:11.5px;color:var(--fg-3);margin-top:5px;display:flex;align-items:center;gap:5px}.cols-2{grid-template-columns:1.6fr 1fr}.cols-2b{grid-template-columns:1fr 1fr}@media(max-width:1100px){.cols-2,.cols-2b{grid-template-columns:1fr}}.up{color:var(--up)}.down{color:var(--down)}.muted{color:var(--fg-3)}.tri{display:inline-block;width:0;height:0;vertical-align:middle}.tri-up{border-left:4px solid transparent;border-right:4px solid transparent;border-bottom:6px solid var(--up)}.tri-down{border-left:4px solid transparent;border-right:4px solid transparent;border-top:6px solid var(--down)}.dot{display:inline-block;width:7px;height:7px;border-radius:50%}.dot.up{background:var(--up)}.dot.down{background:var(--down)}.pill{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:3px 8px;border-radius:20px;border:1px solid var(--border);color:var(--fg-2);letter-spacing:.02em}.pill.long::before{content:"";width:0;height:0;border-left:3px solid transparent;border-right:3px solid transparent;border-bottom:5px solid var(--fg-2)}.pill.short::before{content:"";width:0;height:0;border-left:3px solid transparent;border-right:3px solid transparent;border-top:5px solid var(--fg-2)}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:13px}thead th{text-align:left;font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-3);font-weight:600;padding:12px 16px;border-bottom:1px solid var(--border);white-space:nowrap;cursor:pointer;user-select:none}thead th .ar{opacity:.5;font-size:9px;margin-left:3px}tbody td{padding:13px 16px;border-bottom:1px solid var(--border);white-space:nowrap}tbody tr{transition:background .12s var(--ease)}tbody tr:hover{background:var(--hover)}tbody tr:last-child td{border-bottom:none}.sym{font-weight:600;letter-spacing:.01em}.t-actions{display:flex;gap:4px;opacity:0;transition:opacity .12s}tr:hover .t-actions{opacity:1}.tfilters{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-bottom:14px}.tfilters .grp{display:flex;align-items:center;gap:9px}.tfilters .grp>span{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--fg-3);font-weight:600}.fseg{display:inline-flex;border:1px solid var(--border);border-radius:var(--r-sm);overflow:hidden}.fseg button{padding:6px 13px;font-size:12px;font-weight:600;color:var(--fg-3);transition:.12s var(--ease)}.fseg button:not(:last-child){border-right:1px solid var(--border)}.fseg button.on{background:var(--fg);color:var(--bg)}.fseg button:not(.on):hover{background:var(--hover);color:var(--fg)}.hl-chip{display:inline-flex;align-items:center;gap:9px;margin-left:auto;font-size:12px;color:var(--fg-2);background:var(--surface-2);border:1px solid var(--border);border-radius:20px;padding:5px 7px 5px 13px}.hl-chip b{color:var(--fg);font-weight:600}.hl-chip button{width:20px;height:20px;display:grid;place-items:center;border-radius:50%;color:var(--fg-3);font-size:12px;transition:.12s var(--ease)}.hl-chip button:hover{background:var(--hover);color:var(--fg)}tbody tr.row-hl{background:color-mix(in srgb,var(--fg) 9%,transparent);animation:rowHL 1.7s var(--ease)}tbody tr.row-hl>td:first-child{box-shadow:inset 3px 0 0 var(--fg)}@keyframes rowHL{0%,35%{background:color-mix(in srgb,var(--fg) 22%,transparent)}100%{background:color-mix(in srgb,var(--fg) 9%,transparent)}}tbody tr.has-note>td{border-bottom:none}tbody tr.note-row td{padding:0 16px 13px;white-space:normal;color:var(--fg-2);font-size:12.5px;font-style:italic;line-height:1.5}tbody tr.note-row:hover{background:transparent}tbody tr.note-row.row-hl:hover{background:color-mix(in srgb,var(--fg) 9%,transparent)}.note-q{color:var(--fg-3);font-size:17px;font-style:normal;margin-right:5px;font-family:var(--mono);vertical-align:-3px}.chart-link{display:inline-flex;align-items:center;gap:5px;font-style:normal;font-size:12px;font-weight:600;letter-spacing:.01em;color:var(--fg-2);text-decoration:none;border-bottom:1px solid var(--bd);padding-bottom:1px;transition:color .15s,border-color .15s;vertical-align:1px}.chart-link.ml{margin-left:14px}.chart-link:hover{color:var(--fg);border-color:var(--fg)}.chart-link svg{width:13px;height:13px;flex:none}.icon-btn{width:28px;height:28px;display:grid;place-items:center;border-radius:6px;color:var(--fg-3);transition:.12s}.icon-btn:hover{background:var(--active);color:var(--fg)}.icon-btn svg{width:15px;height:15px}.rating{display:inline-flex;gap:2px}.rating i{width:5px;height:5px;border-radius:50%;background:var(--border-2)}.rating i.on{background:var(--fg)}.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:70px 20px;gap:14px}.empty .e-mark{width:54px;height:54px;border:1.5px solid var(--border-2);border-radius:14px;display:grid;place-items:center;color:var(--fg-3)}.empty .e-mark svg{width:26px;height:26px}.empty h3{font-size:16px;font-weight:600}.empty p{font-size:13px;color:var(--fg-3);max-width:340px}.empty .actions{display:flex;gap:10px;margin-top:6px}.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(4px);z-index:100;display:none;align-items:flex-start;justify-content:center;padding:40px 20px;overflow-y:auto}.modal-bg.open{display:flex;animation:fade .2s var(--ease)}.modal{background:var(--surface);border:1px solid var(--border-2);border-radius:var(--r-lg);width:100%;max-width:680px;box-shadow:var(--shadow)}.modal-h{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border)}.modal-h h3{font-size:16px;font-weight:600}.modal-b{padding:22px 24px;display:grid;grid-template-columns:repeat(2,1fr);gap:15px}.form-row{display:flex;flex-direction:column;gap:6px}.form-row.full{grid-column:1/-1}.form-row label{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--fg-3)}.form-row input,.form-row select,.form-row textarea{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-sm);padding:10px 12px;outline:none;transition:border .15s var(--ease);width:100%}.form-row input:focus,.form-row select:focus,.form-row textarea:focus{border-color:var(--border-2)}.form-row textarea{resize:none;min-height:84px;font-family:inherit}.form-row .hint{font-size:11px;color:var(--fg-3)}.in-unit{position:relative;display:block}.in-unit input{padding-right:32px}.in-unit-s{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--fg-3);font-size:13px;font-weight:600;pointer-events:none}.seg{display:flex;border:1px solid var(--border);border-radius:var(--r-sm);overflow:hidden}.seg button{flex:1;padding:9px;font-size:13px;font-weight:600;color:var(--fg-3);transition:.12s}.seg button.on{background:var(--fg);color:var(--bg)}.calc{grid-column:1/-1;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-sm);padding:13px 15px;display:flex;align-items:center;justify-content:space-between;gap:14px}.calc .pnl-prev{font-size:22px;font-weight:600;font-family:var(--mono)}.calc label{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--fg-2);cursor:pointer}.calc input[type=number]{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);padding:9px 12px;color:var(--fg);font-size:14px;font-family:var(--mono);text-align:right;outline:none;transition:border .15s var(--ease)}.calc input[type=number]:focus{border-color:var(--border-2)}input[type=checkbox]{appearance:none;-webkit-appearance:none;flex:none;width:16px;height:16px;border:1px solid var(--border-2);border-radius:5px;background:var(--surface);cursor:pointer;position:relative;transition:background .12s var(--ease),border-color .12s var(--ease)}input[type=checkbox]:hover{border-color:var(--fg-3)}input[type=checkbox]:checked{background:var(--fg);border-color:var(--fg)}input[type=checkbox]:checked::after{content:"";position:absolute;left:5px;top:2px;width:4px;height:8px;border:solid var(--bg);border-width:0 2px 2px 0;transform:rotate(45deg)}.star{display:inline-flex;gap:4px}.star button{font-size:18px;color:var(--border-2);line-height:1}.star button.on{color:var(--fg)}.modal-f{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:18px 24px;border-top:1px solid var(--border)}.btn-ghost{padding:9px 15px;border:1px solid var(--border);border-radius:var(--r-sm);font-size:13px;font-weight:600;color:var(--fg-2);transition:.12s}.btn-ghost:hover{background:var(--hover);color:var(--fg)}.btn-danger{color:var(--down);border-color:transparent}.btn-danger:hover{background:color-mix(in srgb,var(--down) 14%,transparent)}@media(max-width:560px){.modal-b{grid-template-columns:1fr}}.day-b{padding:14px 18px 20px;display:flex;flex-direction:column;gap:9px;max-height:64vh;overflow-y:auto}.day-net{display:flex;align-items:center;justify-content:space-between;padding:2px 2px 8px;font-size:12.5px;color:var(--fg-3)}.day-net .num{font-family:var(--mono);font-weight:600}.day-trade{border:1px solid var(--border);border-radius:var(--r-sm);padding:12px 14px;display:flex;flex-direction:column;gap:8px;cursor:pointer;transition:border .12s,background .12s}.day-trade:hover{border-color:var(--border-2);background:var(--hover)}.day-trade .dt-top{display:flex;align-items:center;gap:9px}.day-trade .dt-sym{font-weight:600;letter-spacing:.01em}.day-trade .dt-pnl{margin-left:auto;font-family:var(--mono);font-weight:600}.day-trade .dt-meta{display:flex;flex-wrap:wrap;gap:3px 12px;font-size:12px;color:var(--fg-3);font-family:var(--mono)}.day-trade .dt-note{font-size:12.5px;color:var(--fg-2);font-style:italic;line-height:1.5}.day-trade .dt-actions{display:flex;gap:14px;align-items:center}.tip{position:fixed;z-index:200;background:var(--surface-3);border:1px solid var(--border-2);border-radius:8px;padding:8px 11px;font-size:12px;pointer-events:none;opacity:0;transition:opacity .12s;box-shadow:var(--shadow);white-space:nowrap}.tip .t-row{display:flex;justify-content:space-between;gap:14px}.tip .t-lab{color:var(--fg-3)}.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--fg);color:var(--bg);padding:11px 18px;border-radius:10px;font-size:13px;font-weight:600;z-index:300;opacity:0;transition:.25s var(--ease);box-shadow:var(--shadow)}.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}.chart{width:100%;display:block}.eq-wrap{position:relative;width:100%}.eq-ylab{position:absolute;left:0;transform:translateY(-50%);text-align:right;padding-right:8px;font-family:var(--mono);font-size:10px;line-height:1;color:var(--fg-3);pointer-events:none;white-space:nowrap;font-variant-numeric:tabular-nums}.eq-line{stroke-dasharray:1;stroke-dashoffset:1;animation:eqDraw 1.05s var(--ease) forwards}.eq-area{opacity:0;animation:eqFade .9s var(--ease) .35s forwards}@keyframes eqDraw{to{stroke-dashoffset:0}}@keyframes eqFade{to{opacity:1}}@media (prefers-reduced-motion:reduce){.eq-line{animation:none;stroke-dashoffset:0}.eq-area{animation:none;opacity:1}}.eq-dot{position:absolute;width:9px;height:9px;border-radius:50%;transform:translate(-50%,-50%);background:var(--bg);border:1.6px solid var(--fg);cursor:pointer;opacity:.32;transition:width .14s var(--ease),height .14s var(--ease),background .14s var(--ease),box-shadow .14s var(--ease),opacity .2s var(--ease)}.eq-dot.loss{border-style:dashed}.eq-wrap:hover .eq-dot{opacity:.9}.eq-dot:hover{width:14px;height:14px;background:var(--fg);box-shadow:0 0 0 4px color-mix(in srgb,var(--fg) 12%,transparent);opacity:1;z-index:5}.eq-dot.end{width:10px;height:10px;border-color:transparent;opacity:1}.eq-dot.end.up{background:var(--up)}.eq-dot.end.down{background:var(--down)}.eq-dot.end:hover{width:14px;height:14px;box-shadow:0 0 0 4px color-mix(in srgb,var(--fg) 14%,transparent)}.legend{display:flex;gap:16px;flex-wrap:wrap;font-size:12px;color:var(--fg-2)}.legend span{display:flex;align-items:center;gap:7px}.lg-box{width:11px;height:11px;border-radius:3px;border:1px solid var(--border-2)}.bars-list{display:flex;flex-direction:column;gap:11px}.bar-row{display:grid;grid-template-columns:90px 1fr auto;align-items:center;gap:12px;font-size:12.5px}.bar-row .bl{color:var(--fg-2);font-weight:500;overflow:hidden;text-overflow:ellipsis}.bar-row.bar-click{cursor:pointer;border-radius:6px;margin:0 -7px;padding:3px 7px;transition:background .15s var(--ease)}.bar-row.bar-click:hover{background:color-mix(in srgb,var(--fg) 8%,transparent)}.bar-row.bar-click:hover .bl{color:var(--fg)}.bar-track{height:9px;background:var(--surface-2);border-radius:20px;overflow:hidden;position:relative}.bar-fill{height:100%;border-radius:20px;transform-origin:left center;animation:barGrow .7s var(--ease)}@keyframes barGrow{from{transform:scaleX(0)}to{transform:scaleX(1)}}.bar-val{font-family:var(--mono);font-size:12px;text-align:right;min-width:74px}@media(prefers-reduced-motion:reduce){.nav button.active svg,.bar-fill{animation:none}}.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.cal-nav{display:flex;align-items:center;gap:6px}.cal-month{font-size:15px;font-weight:600;min-width:150px;text-align:center}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:7px}.cal-dow{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-3);text-align:center;font-weight:600;padding-bottom:4px}.cal-cell{aspect-ratio:1;border:1px solid var(--border);border-radius:9px;padding:7px 8px;display:flex;flex-direction:column;justify-content:space-between;position:relative;transition:.12s;min-height:62px}.cal-cell.empty{border:none;background:transparent}.cal-cell.has:hover{border-color:var(--border-2);transform:translateY(-1px)}.cal-cell.has{cursor:pointer}.cal-d{font-size:11px;color:var(--fg-3);font-weight:500}.cal-cell.today{box-shadow:inset 0 0 0 1.5px var(--border-2)}.cal-cell.today .cal-d{color:var(--fg);font-weight:700}.cal-pnl{font-size:12px;font-weight:600;font-family:var(--mono);color:var(--fg)}.cal-pnl .short{display:none}.cal-cnt{font-size:9.5px;color:var(--fg-3)}.cal-cell .corner{position:absolute;top:8px;right:8px}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1px;background:var(--border);border-radius:var(--r);overflow:hidden}.stat-grid .s{background:var(--surface);padding:16px 18px}.stat-grid .s .l{font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-3);font-weight:600}.stat-grid .s .v{font-size:20px;font-weight:600;margin-top:7px;font-family:var(--mono)}.kpi{position:relative;overflow:hidden;transition:transform .28s var(--ease),border-color .28s var(--ease),box-shadow .28s var(--ease)}.kpi::before{content:"";position:absolute;left:0;right:0;top:0;height:1px;background:linear-gradient(90deg,transparent,var(--border-2),transparent);opacity:0;transition:opacity .28s var(--ease)}.kpi:hover{transform:translateY(-3px);border-color:var(--border-2);box-shadow:var(--shadow)}.kpi:hover::before{opacity:1}.btn-primary:active{transform:scale(.97)}.btn-ghost:active,.ghost:active{transform:scale(.98)}@media(prefers-reduced-motion:reduce){.kpi{transition:none}.kpi:hover{transform:none}}.rr-prev{margin-top:5px;font-size:12.5px;font-family:var(--mono);font-weight:600;color:var(--fg-2);letter-spacing:.02em}.rr-prev .rr-k{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-3);margin-right:4px}.rr-prev.up{color:var(--up)}.rr-prev.down{color:var(--down)}#charts-list{display:flex;flex-direction:column;gap:8px}.chart-row{display:flex;align-items:center;gap:8px}.chart-row .ch-tf{width:62px;flex:0 0 62px;text-align:center;font-family:var(--mono);font-size:12.5px}.chart-row .ch-url{flex:1 1 auto;min-width:0;font-size:12.5px}.chart-row .ch-thumb{flex:1 1 auto;height:40px;border-radius:var(--r-sm);border:1px solid var(--border);background-size:cover;background-position:center;background-repeat:no-repeat;cursor:zoom-in;transition:border-color .15s var(--ease)}.chart-row .ch-thumb:hover{border-color:var(--border-2)}.chart-row .icon-btn{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--border);border-radius:var(--r-sm);color:var(--fg-3);transition:.12s}.chart-row .icon-btn:hover{color:var(--down);border-color:var(--border-2)}.ch-add-row{display:flex;gap:8px;margin-top:9px}.btn-ghost.ch-add{display:inline-flex;align-items:center;gap:6px}.btn-ghost.ch-add svg{width:14px;height:14px}#img-lb{position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;padding:32px;background:rgba(0,0,0,.82);backdrop-filter:blur(4px);animation:fade .18s var(--ease)}#img-lb.open{display:flex}#img-lb img{max-width:100%;max-height:100%;border-radius:var(--r);box-shadow:var(--shadow);object-fit:contain}#img-lb .lb-x{position:absolute;top:18px;right:22px;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid var(--border-2);color:#fff;font-size:18px;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.15s}#img-lb .lb-x:hover{background:rgba(255,255,255,.16)}.pnl-manual-side{display:flex;flex-direction:column;align-items:flex-end;gap:8px}.pnl-manual-cap{font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-3);font-weight:600}.pnl-manual-wrap{display:flex;flex-direction:column;align-items:flex-end;gap:7px}.seg.pnl-unit{width:auto;align-self:flex-end}.seg.pnl-unit button{flex:0 0 auto;padding:6px 12px;font-size:12px}.calc #pnl-manual{width:140px}.pnl-pct-row{display:flex;align-items:center;gap:7px}.calc .pnl-pct-row input{width:92px}.pnl-of{color:var(--fg-3);font-size:12px}.pnl-conv{font-size:11px;color:var(--fg-3);font-family:var(--mono)}.date-pair{display:grid;grid-template-columns:1fr 1fr;gap:15px}@media(max-width:560px){.date-pair{grid-template-columns:1fr}.calc{flex-direction:column;align-items:stretch;gap:13px}.pnl-manual-side{align-items:stretch}.pnl-manual-wrap{align-items:stretch}.seg.pnl-unit{align-self:stretch}.seg.pnl-unit button{flex:1}.calc #pnl-manual,.calc .pnl-pct-row input{width:100%}}.date-pair.one{grid-template-columns:1fr}.settings-wrap{display:flex;flex-direction:column;gap:16px;max-width:900px;width:100%;margin:0 auto}.set-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r)}.set-card-h{padding:16px 20px;border-bottom:1px solid var(--border)}.set-card-h h3{font-size:13px;font-weight:600;letter-spacing:.02em}.set-card-h .sub{display:block;margin-top:5px;line-height:1.55}.set-list{padding:4px 20px}.set-grid{display:grid;grid-template-columns:1fr 1fr;column-gap:36px}.set-grid .set-row:nth-last-child(2){border-bottom:none}.set-row{display:flex;align-items:center;gap:16px;padding:13px 0;border-bottom:1px solid var(--border)}.set-list .set-row:last-child{border-bottom:none}.set-info{flex:1;min-width:0}.set-info b{display:block;font-size:13px;font-weight:600}.set-info small{display:block;color:var(--fg-3);font-size:11px;margin-top:2px}.set-lock{display:inline-flex;align-items:center;justify-content:center;width:40px;height:22px;color:var(--fg-3);flex:none}.set-lock svg{width:15px;height:15px}.set-empty{padding:18px 0;text-align:center;color:var(--fg-3);font-size:12px}.tgl{position:relative;width:40px;height:22px;flex:none;border-radius:999px;background:var(--bg-2);border:1px solid var(--border);cursor:pointer;transition:background .2s var(--ease),border-color .2s var(--ease)}.tgl-k{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:var(--fg-3);transition:transform .22s var(--ease),background .22s var(--ease)}.tgl.on{background:var(--fg);border-color:var(--fg)}.tgl.on .tgl-k{transform:translateX(18px);background:var(--bg)}.cf-add{display:flex;gap:8px;padding:16px 20px;border-top:1px solid var(--border);flex-wrap:wrap;align-items:center}.cf-add input{flex:1;min-width:150px;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-sm);padding:10px 12px;outline:none;transition:border .15s var(--ease)}.cf-add input:focus{border-color:var(--border-2)}.cf-type{display:inline-flex;border:1px solid var(--border);border-radius:var(--r-sm);overflow:hidden}.cf-type button{padding:9px 14px;font-size:12px;font-weight:600;color:var(--fg-3);transition:.12s var(--ease)}.cf-type button.on{background:var(--fg);color:var(--bg)}.cf-type button:not(.on):hover{background:var(--hover);color:var(--fg)}.cf-del{color:var(--fg-3);flex:none}.cf-del:hover{color:var(--down)}@media(max-width:880px){body{grid-template-columns:1fr}.sidebar{position:fixed;left:0;top:0;z-index:50;transform:translateX(-100%);transition:transform .25s var(--ease);box-shadow:var(--shadow)}.sidebar.open{transform:none}.content,.topbar{padding-left:18px;padding-right:18px}}.menu-btn{display:none}@media(max-width:880px){.menu-btn{display:grid;place-items:center;width:38px;height:38px;border:1px solid var(--border);border-radius:var(--r-sm)}}.sb-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:40}@media(max-width:880px){.sb-overlay.open{display:block}}@media(max-width:640px){.sail-lane{display:none}.topbar{position:static;flex-wrap:wrap;gap:11px 12px;padding:13px 15px}.topbar .title{flex:1 1 auto;min-width:0}.topbar h2{font-size:17px}.controls{flex-basis:100%;gap:8px}.controls .field{flex:1 1 100%}.field input{width:100%}.controls .dd{flex:1 1 0;min-width:0}.dd-btn{width:100%}#btn-add{flex:1 1 100%;justify-content:center}.content{padding:16px 15px 54px}.grid{gap:13px}.kpis{grid-template-columns:1fr 1fr;gap:12px}.kpi{padding:14px}.kpi .val{font-size:22px}.card-h{padding:14px 16px}.card-pad{padding:15px 16px}thead th{padding:10px 12px}tbody td{padding:11px 12px}.t-actions{opacity:1}.cal-grid{gap:3px}.cal-cell{min-width:0;overflow:hidden;min-height:52px;padding:5px 3px;border-radius:7px}.cal-cell .corner{top:5px;right:5px}.cal-d{font-size:10px}.cal-pnl{font-size:9.5px;letter-spacing:-.02em}.cal-pnl .ar,.cal-pnl .full,.cal-cnt{display:none}.cal-pnl .short{display:inline}.eq-wrap svg.chart{height:230px!important}.tfilters{gap:12px 14px;margin-bottom:12px}}@keyframes pulse{0%{box-shadow:0 0 0 0 color-mix(in srgb,var(--up) 50%,transparent)}70%{box-shadow:0 0 0 7px transparent}100%{box-shadow:0 0 0 0 transparent}}@keyframes wcUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}@keyframes wcBob{0%,100%{transform:translateY(0) rotate(-1.5deg)}50%{transform:translateY(-5px) rotate(1.5deg)}}#welcome{position:fixed;inset:0;z-index:200;background:var(--bg);display:none;align-items:center;justify-content:center;padding:34px 20px;overflow-y:auto}html.show-welcome #welcome{display:flex}#welcome.open{display:flex;animation:fade .35s var(--ease)}.wc-theme{position:absolute;top:18px;right:20px;width:34px;height:34px;border:1px solid var(--border);border-radius:var(--r-sm)}.wc-card{width:100%;max-width:412px;display:flex;flex-direction:column;align-items:center;text-align:center;animation:wcUp .5s var(--ease) both}.wc-card .logo-img{width:76px;height:68px;margin-bottom:8px;animation:wcBob 5.5s var(--ease) infinite}.wc-word{font-size:12px;letter-spacing:.34em;font-weight:700;color:var(--fg)}.wc-word small{display:block;font-size:9px;letter-spacing:.42em;color:var(--fg-3);font-weight:500;margin-top:3px}.wc-card h2{font-size:26px;font-weight:700;letter-spacing:-.02em;margin:22px 0 9px}.wc-card .lede{font-size:14px;line-height:1.55;color:var(--fg-2);max-width:344px}.wc-form{width:100%;margin-top:24px;display:flex;flex-direction:column;gap:10px}.wc-input{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);padding:13px 15px;color:var(--fg);font-size:14px;font-family:var(--sans);outline:none;transition:border-color .15s var(--ease)}.wc-input::placeholder{color:var(--fg-3)}.wc-input:focus{border-color:var(--border-2)}.wc-enter{width:100%;justify-content:center;padding:13px;font-size:14px}.wc-hint{font-size:11.5px;color:var(--fg-3)}.wc-soon{width:100%;margin-top:24px;border:1px solid var(--border);border-radius:var(--r);background:color-mix(in srgb,var(--surface) 55%,transparent);padding:16px;text-align:left}.wc-soon-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.wc-soon-h b{font-size:12.5px;font-weight:600;color:var(--fg-2)}.wc-pill{display:inline-flex;align-items:center;gap:6px;font-size:10px;font-weight:600;letter-spacing:.04em;color:var(--fg-3);border:1px solid var(--border);border-radius:999px;padding:3px 9px}.wc-pill::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--up);box-shadow:0 0 0 0 color-mix(in srgb,var(--up) 55%,transparent);animation:pulse 2.6s var(--ease) infinite}.wc-ghost-field{display:flex;align-items:center;gap:9px;border:1px solid var(--border);border-radius:var(--r-sm);padding:11px 12px;margin-top:9px;color:var(--fg-3);font-size:13px;opacity:.7}.wc-ghost-field svg{width:15px;height:15px;flex:none}.wc-note{font-size:11.5px;line-height:1.55;color:var(--fg-3);margin-top:22px;max-width:352px}.wc-note b{color:var(--fg-2);font-weight:600}.side-user{display:flex;align-items:center;gap:9px;padding:8px 9px;border:1px solid var(--border);border-radius:var(--r-sm);margin-bottom:8px}.side-user .av{width:30px;height:30px;border-radius:50%;flex:none;display:grid;place-items:center;background:var(--surface-2);color:var(--fg);font-size:12px;font-weight:700;font-family:var(--mono);text-transform:uppercase}.side-user .who{min-width:0;flex:1;line-height:1.25}.side-user .who b{display:block;font-size:12.5px;font-weight:600;color:var(--fg);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.side-user .who small{font-size:9.5px;color:var(--fg-3)}@media (prefers-reduced-motion:reduce){.wc-card .logo-img,.wc-pill::before{animation:none}}@media(max-width:820px){.set-grid{grid-template-columns:1fr}.set-grid .set-row:nth-last-child(2){border-bottom:1px solid var(--border)}}.table-wrap th,.table-wrap td{padding-left:12px;padding-right:12px}.table-wrap{scrollbar-width:thin;scrollbar-color:var(--fg-3) transparent}.table-wrap::-webkit-scrollbar{height:12px;width:12px}.table-wrap::-webkit-scrollbar-thumb{background:var(--fg-3);border-radius:20px;border:3px solid transparent;background-clip:content-box}.table-wrap::-webkit-scrollbar-thumb:hover{background:var(--fg-2)}.table-wrap::-webkit-scrollbar-track{background:transparent}

/* ===== Economic calendar (monochrome) ===== */
.cal-eco{max-width:940px;margin:0 auto}
.cal-eco-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px;flex-wrap:wrap}
.cal-eco-l{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.seg.cal-imp button{font-family:var(--mono);font-size:12px}
.cal-refresh{width:32px;height:32px}
.cal-refresh.spin svg{animation:calspin .9s linear infinite}
@keyframes calspin{to{transform:rotate(360deg)}}
.cal-upd{font-size:12px;color:var(--fg-3);font-family:var(--mono)}
.cal-off{margin-left:8px;color:var(--down);font-size:11.5px}
.cal-disconnect{font-size:12px}
.cal-cur{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}
.cal-cur button{font-family:var(--mono);font-size:11.5px;padding:4px 10px;border:1px solid var(--border);background:var(--surface);color:var(--fg-2);border-radius:999px;cursor:pointer;transition:border-color .15s,background .15s,color .15s}
.cal-cur button:hover{border-color:var(--border-2);color:var(--fg)}
.cal-cur button.on{background:var(--fg);color:var(--bg);border-color:var(--fg)}
.cal-days{display:flex;flex-direction:column;gap:20px}
.cal-day-h{display:flex;align-items:center;gap:10px;font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--fg-3);padding-bottom:8px;border-bottom:1px solid var(--border);margin-bottom:6px}
.cal-day.today .cal-day-h{color:var(--fg)}
.cal-today-pill{font-size:10px;padding:1px 8px;border-radius:999px;background:var(--fg);color:var(--bg);letter-spacing:.06em}
.cal-day-n{margin-left:auto;font-family:var(--mono);color:var(--fg-3);font-weight:500}
.cal-ev{display:grid;grid-template-columns:56px 48px 32px 1fr auto;align-items:center;gap:12px;padding:9px 10px;border-radius:8px;transition:background .15s}
.cal-ev:hover{background:var(--surface)}
.cal-ev.past{opacity:.46}
.cal-ev.up-next{background:var(--surface-2);box-shadow:inset 2px 0 0 var(--fg)}
.cal-time{font-family:var(--mono);font-size:12.5px;color:var(--fg-2)}
.cal-ccy{font-family:var(--mono);font-size:11px;font-weight:600;color:var(--fg);border:1px solid var(--border-2);border-radius:5px;padding:2px 0;text-align:center;letter-spacing:.02em}
.cal-imp-mark{display:inline-flex;gap:2px;align-items:flex-end;height:14px}
.cal-imp-mark i{width:3px;height:5px;background:var(--surface-3);border-radius:1px}
.cal-imp-mark i:nth-child(2){height:9px}
.cal-imp-mark i:nth-child(3){height:13px}
.cal-imp-mark.imp-low i:nth-child(1){background:var(--fg-3)}
.cal-imp-mark.imp-medium i:nth-child(1),.cal-imp-mark.imp-medium i:nth-child(2){background:var(--fg-2)}
.cal-imp-mark.imp-high i{background:var(--down)}
.cal-title{font-size:13.5px;color:var(--fg);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cal-fc{display:flex;flex-direction:column;align-items:flex-end;font-family:var(--mono);line-height:1.25}
.cal-fc b{font-size:12.5px;font-weight:600;color:var(--fg)}
.cal-fc small{font-size:10.5px;color:var(--fg-3)}
.cal-foot{margin-top:22px;font-size:11.5px;color:var(--fg-3);text-align:center}
.cal-skel{display:flex;flex-direction:column;gap:10px;margin-top:8px}
.cal-skel-row{height:42px;border-radius:8px;background:linear-gradient(90deg,var(--surface) 25%,var(--surface-2) 37%,var(--surface) 63%);background-size:400% 100%;animation:calsk 1.3s ease infinite}
@keyframes calsk{0%{background-position:100% 0}100%{background-position:-100% 0}}
.cal-setup{max-width:560px;margin:6vh auto 0;text-align:center}
.cal-setup .e-mark{margin:0 auto 16px}
.cal-setup h3{font-size:20px;margin:0 0 8px}
.cal-setup p{color:var(--fg-2);line-height:1.6;margin:0 0 18px}
.cal-connect{display:flex;gap:8px;margin-bottom:16px}
.cal-connect input{flex:1}
.cal-help{text-align:left;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px 14px}
.cal-help summary{cursor:pointer;font-weight:600;font-size:13px}
.cal-help ol{margin:10px 0 8px 18px;color:var(--fg-2);line-height:1.7;font-size:13px}
.cal-help-note{font-size:12px;color:var(--fg-3);margin:6px 0 0;line-height:1.6}
@media(max-width:640px){.cal-ev{grid-template-columns:50px 42px 28px 1fr;row-gap:2px}.cal-fc{grid-column:3/-1;align-items:flex-start;flex-direction:row;gap:8px}}
.cal-demo-badge{margin-left:8px;display:inline-flex;align-items:center;gap:5px;padding:2px 8px;border:1px solid var(--border-2);border-radius:999px;background:var(--surface-2);color:var(--fg-2);font-size:10.5px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;vertical-align:middle}.cal-demo-badge::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--fg-3)}