

    /* Color scheme variables (best-effort match to) */
    :root{
      --trl-bg-0:#060A12;
      --trl-bg-1:#0B1220;
      --trl-bg-2:#0E1730;
      --trl-card:#0E1628;
      --trl-card-2:#0B1220;
      --trl-border:rgba(255,255,255,.08);
      --trl-border-2:rgba(255,255,255,.10);
      --trl-text:#E8EEF9;
      --trl-muted:rgba(232,238,249,.72);
      --trl-accent:#2D6BFF;
      --trl-green:#1DE77B;
      --trl-red:#FF4D5E;
      --trl-blue:#4B86FF;
    }

    body{ background: radial-gradient(1200px 800px at 50% -10%, rgba(45,107,255,.18), transparent 60%),
                    radial-gradient(900px 700px at 12% 18%, rgba(29,231,123,.10), transparent 55%),
                    radial-gradient(900px 700px at 88% 22%, rgba(255,77,94,.08), transparent 55%),
                    linear-gradient(180deg, var(--trl-bg-1), var(--trl-bg-0) 55%, #050711);
          color: var(--trl-text);
    }

    .card, .panel, .glass, .sheet{
      background: linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.015));
      border: 1px solid var(--trl-border);
    }

    
    .sumSection{ margin-top: 10px; }
    .sumSectionTitle{
      font-weight: 700;
      letter-spacing: .2px;
      font-size: 14px;
      color: rgba(232,238,249,.78);
      margin: 6px 4px 10px;
      display:flex;
      align-items:center;
      gap:10px;
    }
    .sumSectionTitle:after{
      content:'';
      height:1px;
      flex:1;
      background: linear-gradient(90deg, rgba(255,255,255,.12), transparent);
    }

.bubble{
      border: 1px solid var(--trl-border);
      background: linear-gradient(180deg, rgba(255,255,255,.040), rgba(255,255,255,.018));
      cursor: default;
      user-select: text;
    }
    .bubble.green{ background: linear-gradient(180deg, rgba(29,231,123,.10), rgba(29,231,123,.04)); }
    .bubble.red{ background: linear-gradient(180deg, rgba(255,77,94,.10), rgba(255,77,94,.04)); }
    .bubble.blue{ background: linear-gradient(180deg, rgba(75,134,255,.12), rgba(75,134,255,.05)); }
.bubble.gray{ 
      border-color: rgba(148,163,184,.25);
      background: linear-gradient(180deg, rgba(148,163,184,.10), rgba(148,163,184,.03));
    }
    .bubble.gray .v{ color: rgba(226,232,240,.88); }
    .bubble.gray .s{ color: rgba(148,163,184,.90); }

    .muted{ color: var(--trl-muted); }

    /* Desktop scale removed: sections are full-width (no zoom/scale). */
:root{
      --bg:#0E1117;
      --fg:#ffffff;
      --muted:#9aa4b2;
      --card:#1a1f2e;
      --border:#252b3a;
      --input:#0E1117;
      --inputBorder:#3a4258;
      --shadow: 0 10px 30px rgba(0,0,0,.25);
      --blue:#2563eb;
      --blue2:#3b82f6;
      --green:#22c55e;
      --red:#ef4444;
      --yellow:#f59e0b;
    }
    [data-theme="light"]{
      --bg:#f8fafc;
      --fg:#0f172a;
      --muted:#475569;
      --card:#ffffff;
      --border:#d1d5db;
      --input:#f3f4f6;
      --inputBorder:#cbd5e1;
      --shadow: 0 10px 25px rgba(2,6,23,.08);
    }
    *{box-sizing:border-box}
    body{
      margin:0;
      font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
      background:var(--bg);
      color:var(--fg);
      min-height:100vh;
          zoom:0.85; /* compact view (like 90% zoom) */
    }
    @media (max-width: 720px){
      body{zoom:1;}
    }

    a{color:inherit}
    .container{max-width:1600px;margin:0 auto;padding:96px 16px 12px;width:100%}
    @media (max-width: 720px){
      .container{padding-left:12px;padding-right:12px;}
    }
    .headerWrap{
      position:sticky;top:0;z-index:50;
      border-bottom:1px solid var(--border);
      background:var(--bg);
      backdrop-filter:saturate(1.2) blur(8px);
    }
    .header{
      max-width:1600px;margin:0 auto;padding:16px 16px;
      display:flex;align-items:center;justify-content:space-between;gap:16px;
    }
    .brand{display:flex;align-items:center;gap:12px;min-width:0}
    .logo{
      width:40px;height:40px;border-radius:14px;
      background:linear-gradient(135deg,#a855f7,#ec4899);
      display:grid;place-items:center;
      box-shadow:0 10px 25px rgba(168,85,247,.25);
    }
    .brand h1{margin:0;font-size:18px}
    .brand p{margin:2px 0 0;color:var(--muted);font-size:12px;white-space:nowrap;overflow:visible;text-overflow:ellipsis}
    .btn{
      appearance:none;border:1px solid var(--border);
      background:transparent;color:var(--fg);
      padding:8px 10px;border-radius:10px;
      cursor:pointer;display:inline-flex;align-items:center;gap:8px;
      transition:transform .08s ease, background .15s ease, border-color .15s ease, opacity .15s ease;
      user-select:none;
    }
    .btn:active{transform:translateY(1px)}
    .btn.primary{background:var(--blue);border-color:rgba(37,99,235,.35);color:#fff}
    .btn.primary:hover{background:var(--blue2)}
    
    [data-theme="dark"] .btn.outline{border-color:#374151;color:#e5e7eb;}
    [data-theme="light"] .btn.outline{border-color:#d1d5db;color:#111827;}
.btn.outline:hover{background:rgba(148,163,184,.12)}
    [data-theme="dark"] .btn.outline:hover{background:rgba(148,163,184,.10)}
    .btn.ghost{border-color:transparent;background:transparent}
    .btn.ghost:hover{background:rgba(239,68,68,.10)}
    .btn:disabled{opacity:.35;cursor:not-allowed;transform:none}
    .card{
      background:var(--card);
      border:1px solid var(--border);
      border-radius:18px;
      box-shadow:var(--shadow);
      padding:18px;
    }
    .card h2,.card h3,.card h4{margin:0}
    .subtitle{color:var(--muted);margin:0;font-size:14px;line-height:1.4}
    .grid{display:grid;gap:16px}
    .grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
    .grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
    .grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
    @media (max-width: 900px){
      .grid-3{grid-template-columns:1fr}
    }
    @media (max-width: 800px){
      .grid-2,.grid-4{grid-template-columns:1fr 1fr}
    }
    @media (max-width: 520px){
      .grid-2,.grid-4{grid-template-columns:1fr 1fr}
    }
    @media (max-width: 420px){
      .grid-2,.grid-4{grid-template-columns:1fr}
    }
    label{display:block;font-size:14px;color:color-mix(in srgb, var(--fg) 78%, transparent);}
    .fieldHead{display:flex;align-items:center;gap:6px;margin-bottom:6px}
    .input, select{
      width:100%;
      padding:10px 12px;
      border-radius:12px;
      border:1px solid var(--inputBorder);
      background:var(--input);
      color:var(--fg);
      outline:none;
      transition:border-color .15s ease, box-shadow .15s ease, background .15s ease;
      font-size:14px;
    }
    select{cursor:pointer}
    .input:focus{
border-color:color-mix(in srgb, var(--blue) 65%, var(--inputBorder));
      box-shadow:0 0 0 3px color-mix(in srgb, var(--blue) 18%, transparent);
    }
select:focus{
border-color:color-mix(in srgb, var(--blue) 65%, var(--inputBorder));
      box-shadow:none; 
    }


    /* Native select styling + arrow visibility + move arrow inward (from html) */
    select.trl-select{
      -webkit-appearance:none;
      -moz-appearance:none;
      appearance:none;
      padding-left:14px; /* avoid clipped text */
      padding-right:42px; /* room for arrow */
      padding-top:10px;   /* prevent descenders clipping */
      padding-bottom:10px;/* prevent descenders clipping */
      text-indent:0;
      background-repeat:no-repeat;
      background-position:right 14px center; /* move arrow inside */
      background-size:16px 16px;
      line-height:1.35;
    }
    [data-theme="dark"] select.trl-select{
      -webkit-appearance:none;
      -moz-appearance:none;
      appearance:none;
      padding-left:14px; /* avoid clipped text */
      padding-right:42px; /* room for arrow */
      padding-top:10px;   /* prevent descenders clipping */
      padding-bottom:10px;/* prevent descenders clipping */
      text-indent:0;
      background-repeat:no-repeat;
      background-position:right 14px center; /* move arrow inside */
      background-size:16px 16px;
      line-height:1.35;
    }
    [data-theme="light"] select.trl-select{
      -webkit-appearance:none;
      -moz-appearance:none;
      appearance:none;
      padding-left:14px; /* avoid clipped text */
      padding-right:42px; /* room for arrow */
      padding-top:10px;   /* prevent descenders clipping */
      padding-bottom:10px;/* prevent descenders clipping */
      text-indent:0;
      background-repeat:no-repeat;
      background-position:right 14px center; /* move arrow inside */
      background-size:16px 16px;
      line-height:1.35;
    }
    [data-theme="light"] select.trl-select option{color:#111827;background:#ffffff;}
    [data-theme="dark"] select.trl-select option{color:#ffffff;background:#0E1117;}


    /* Smaller selects (e.g., h-8 in Profiles) need tighter vertical padding to avoid clipped descenders */
    select.trl-select.trl-select-sm{
      padding-top:6px !important;
      padding-bottom:6px !important;
      line-height:1.2 !important;
    }

    /* h-9 selects (e.g., Margin-based helper) - prevent clipped descenders */
    select.trl-select.trl-select-h9{
      padding-top:8px !important;
      padding-bottom:8px !important;
      line-height:1.2 !important;
    }


    /* Dropdown arrow colors per theme (appearance:none removes native arrow) */
    [data-theme="light"] select.trl-select{
      background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M6 8l4 4 4-4' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    }
    [data-theme="dark"] select.trl-select{
      background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='none'%3E%3Cpath d='M6 8l4 4 4-4' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    }


    /* Checkbox (Filled) – matches TRL control look */
    .trl-check{
      width:18px;height:18px;
      accent-color: var(--blue2);
      cursor:pointer;
    
      margin:0 auto;
      display:block;
    }

    .seg{display:flex;gap:8px;flex-wrap:wrap}
    .seg .btn{padding:7px 10px;border-radius:10px;font-size:13px}
    .seg .btn.active{background:var(--blue);border-color:rgba(37,99,235,.35);color:#fff}

    /* LONG/SHORT switch: active colors (unchosen stays gray)
       NOTE: .seg .btn.active has background/border with !important; override with higher specificity + !important.
             Also, .seg .btn uses border:0 !important; restore border for this specific switch only.
    */
    #posSideSeg .btn{border:1px solid var(--border) !important;}
    #posSideSeg #btnLong.active{background:rgba(34,197,94,.16) !important;border-color:rgba(34,197,94,.35) !important;color:var(--green) !important;}
    #posSideSeg #btnShort.active{background:rgba(239,68,68,.16) !important;border-color:rgba(239,68,68,.35) !important;color:var(--red) !important;}


    
/* Theme icon toggle button (matches style) */
.themeIconBtn{padding:8px 10px;display:inline-flex;align-items:center;justify-content:center;gap:0}
[data-theme="dark"] .themeIconBtn{background:rgba(14,17,23,.85);border-color:#374151;color:#ffffff;}
[data-theme="light"] .themeIconBtn{background:#ffffff;border-color:#d1d5db;color:#0f172a;}

/* Custom dropdown (to match TRL dropdown look) */
.trl-dd{position:relative}
.trl-dd-btn{display:flex;align-items:center;justify-content:space-between;gap:10px;cursor:pointer}
.trl-dd-label{white-space:nowrap;overflow:visible;text-overflow:ellipsis}
.trl-dd-menu{
  position:absolute;left:0;right:0;top:calc(100% + 6px);
  background:var(--input);
  border:1px solid var(--border);
  border-radius:12px;
  box-shadow:0 18px 45px rgba(0,0,0,.35);
  padding:6px;
  display:none;
  z-index:30;
  max-height:260px;
  overflow:auto;
}
[data-theme="light"] .trl-dd-menu{background:#ffffff;box-shadow:0 18px 40px rgba(15,23,42,.12);}
.trl-dd-menu.open{display:block}
.trl-dd-opt{
  padding:10px 10px;
  border-radius:10px;
  cursor:pointer;
  font-size:14px;
  color:var(--fg);
}
.trl-dd-opt:hover{
  background:var(--blue);
  color:#ffffff;
}
.trl-dd-opt[aria-selected="true"]{
  background:transparent;
  color:var(--fg);
  font-weight:800;
}

/* Ladder centering + summary box width */
.ladderCenter{display:flex;flex-direction:column;align-items:stretch}
.ladderStack{display:flex;flex-direction:column;align-items:stretch;gap:10px;width:100%;max-width:100%}
.ladderStack .tableWrap.ladderWrap{align-self:stretch}
#warnBox{width:100%;max-width:100%;align-self:stretch;margin:0;}
/* Segmented buttons (TP/SL inputs): remove white frames, match look */
    .seg .btn{
      border:0 !important;
      background:rgba(148,163,184,.10);
    }
    [data-theme="light"] .seg .btn{background:rgba(15,23,42,.05);}
    .seg .btn:hover{background:rgba(148,163,184,.14);}
    [data-theme="light"] .seg .btn:hover{background:rgba(15,23,42,.08);}
    .seg .btn.active{
      background:var(--blue) !important;
      color:#fff !important;
    }
    .muted{color:var(--muted)}
    .sectionTitle{font-weight:700;font-size:14px;margin-bottom:12px}
    .tableWrap{
      border:1px solid var(--border);
      border-radius:14px;
      overflow:visible;
    }
    table{width:100%;border-collapse:collapse;font-size:13px}
    thead tr{background:rgba(148,163,184,.10)}
    [data-theme="light"] thead tr{background:#f1f5f9}
    th,td{padding:10px 12px;border-top:1px solid color-mix(in srgb, var(--border) 92%, transparent);text-align:left;vertical-align:middle}
    thead th{border-top:none;color:color-mix(in srgb, var(--fg) 78%, transparent);font-weight:700}
    tbody tr:hover{background:rgba(148,163,184,.08)}
    [data-theme="light"] tbody tr:hover{background:#f8fafc}

    /* Ladder table – clearer, more structured */
    .ladderTable{width:100%;border-collapse:separate;border-spacing:0}

    /* Ladder table: compact like Projections table (bigger inputs, no stretching) */
.tableWrap.ladderWrap{
  display:inline-block;
  width:auto;
  max-width:100%;
  margin:0 auto;
  overflow-x:auto;
  overflow-y:visible;
  -webkit-overflow-scrolling: touch;
  /* slightly larger like Projections table (without stretching across full width) */
  zoom:1.14;
}
.tableWrap.ladderWrap .ladderTable{
  width:auto;
  table-layout:fixed;
  min-width:920px; /* bigger/wider but still compact (auto width) */
}

/* Mobile: use full width + scroll if needed */
@media (max-width: 720px){
  .tableWrap.ladderWrap{
    display:block;
    width:100%;
    zoom:1;
  }
  .tableWrap.ladderWrap .ladderTable{
    width:100%;
  }
}
    .ladderTable thead th{
      text-align:center;
      font-size:15px;
      color:color-mix(in srgb, var(--fg) 76%, transparent);
      padding:12px 14px;
      background:color-mix(in srgb, var(--card) 82%, transparent);
      border-bottom:1px solid color-mix(in srgb, var(--border) 72%, transparent);
    }
    .ladderTable tbody td{
      padding:12px 14px;
      text-align:center;
      border-bottom:1px solid color-mix(in srgb, var(--border) 72%, transparent);
      vertical-align:middle;
    }
    .ladderTable tbody tr:hover td{background:rgba(59,130,246,0.06)}
    .ladderTable .colNum{width:56px;text-align:center}
    .ladderTable .colFilled{width:84px;text-align:center}
    .ladderTable .colActions{width:92px;text-align:center}
    .ladderTable .input.mini{
      height:54px;
      border-radius:14px;
      padding:12px 16px;
      font-size:17px;
      text-align:center;
    }
    .ladderTable .btn.ghost{height:52px;min-width:52px;padding:0 14px}

    .ladderTable .closeCell{display:flex;align-items:center;gap:10px}

    .pill{
      display:inline-flex;align-items:center;justify-content:center;
      min-width:24px;height:24px;padding:0 8px;border-radius:999px;
      font-size:12px;font-weight:700;
      background:rgba(37,99,235,.16);color:color-mix(in srgb, var(--blue2) 85%, #fff 0%);
      border:1px solid rgba(37,99,235,.25);
    }
    .pill.green{background:rgba(34,197,94,.16);border-color:rgba(34,197,94,.25);color:var(--green)}
    .pill.red{background:rgba(239,68,68,.16);border-color:rgba(239,68,68,.25);color:var(--red)}
    .mini{
      height:36px;border-radius:12px;padding:8px 10px;font-size:13px
    }

    /* Ladder table input sizing (match reference layout) */
    .ladder-tp{width:260px;max-width:260px;}
    .ladder-close{width:260px;max-width:260px;}

    @media (max-width: 720px){
      .ladder-tp{width:100%;max-width:none;}
      .ladder-close{width:100%;max-width:none;}
    }

.actionsCell{text-align:center;white-space:nowrap}
    .warn{
      margin-top:12px;padding:12px;border-radius:14px;display:flex;gap:10px;align-items:flex-start;
      border:1px solid transparent;
      animation:none;
    }

    /* Stop Total close % box from 'shaking' while typing */
    #warnBox{animation:none !important;}
    #warnBox{min-height:54px;}
    #warnBox .warn{min-height:54px;}
    .warn, .breakEven{animation:none !important;transform:none !important;}
    .warn .small, .beTitle{font-variant-numeric:tabular-nums;}

    @keyframes pop{from{transform:translateY(2px);opacity:.75}to{transform:translateY(0);opacity:1}}
    .warn.red{background:rgba(239,68,68,.10);border-color:rgba(239,68,68,.18);color:var(--red)}
    
/* Allocation info under ladder table */
.allocInfo{
  margin-top:10px;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid var(--border);
  background:rgba(148,163,184,.06);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  width:fit-content;
  max-width:100%;
  margin-left:auto;
  margin-right:auto;
  flex-wrap:wrap;
}
body[data-theme="light"] .allocInfo{background:rgba(15,23,42,.03);}
.allocInfo .allocLeft{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.allocInfo .allocPill{
  font-size:12px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid var(--border);
  background:rgba(148,163,184,.10);
  color:var(--muted);
}
body[data-theme="light"] .allocInfo .allocPill{background:rgba(15,23,42,.05);}
.allocInfo .allocPill.good{
  border-color:rgba(34,197,94,.25);
  background:rgba(34,197,94,.10);
  color:var(--green);
}
.allocInfo .allocPill.bad{
  border-color:rgba(239,68,68,.22);
  background:rgba(239,68,68,.10);
  color:var(--red);
}
.warn.yellow{background:rgba(245,158,11,.10);border-color:rgba(245,158,11,.18);color:color-mix(in srgb, var(--yellow) 85%, var(--fg))}
    .summary h3{margin:0 0 12px;font-size:18px}
    .bubble{
      position:relative;padding:12px;border-radius:16px;
      border:1px solid var(--border);background:rgba(148,163,184,.08);
      cursor:pointer;user-select:none;
      transition:transform .10s ease, border-color .15s ease, background .15s ease;
      overflow:visible;
    }
    [data-theme="light"] .bubble{background:#F3F4F6}
    .bubble:hover{transform:translateY(-1px);border-color:color-mix(in srgb, var(--blue) 45%, var(--border));box-shadow:0 10px 22px rgba(0,0,0,.22);cursor:copy}
    .bubble .t{font-size:13px;color:var(--muted);margin-bottom:4px;display:flex;align-items:center;gap:8px}

    .bubble .tRow{display:flex;align-items:center;justify-content:space-between;gap:10px}
    .bubble .tLabel{min-width:0;overflow:visible;text-overflow:ellipsis;white-space:nowrap}
    .tip.right{margin-left:auto}
    .tip.right .bubbleTip{
      left:auto;right:0;transform:none;
      max-width:360px;min-width:240px;
      white-space:normal;
    }
    .tip.right:hover .bubbleTip{opacity:1;transform:translateY(2px)}
    .tip.right.open .bubbleTip{opacity:1;pointer-events:auto;transform:translateY(2px)}
    .bubble .v{font-size:24px;font-weight:800;white-space:nowrap;overflow:visible;text-overflow:ellipsis}
    .bubble .s{font-size:13px;color:var(--muted);margin-top:4px;white-space:nowrap;overflow:visible;text-overflow:ellipsis}
    .bubble .copyMark{
      position:absolute;right:12px;top:12px;opacity:0;transition:opacity .15s ease;
      display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted);
    }
    .bubble:hover .copyMark{opacity:1}
    /* Hide copy icon (keep copy-on-click functionality) */
    .bubble .copyMark{display:none !important;}

    /* Make bubble values copyable/selectable (like html) */
    .bubble,
    .bubble *{
      -webkit-user-select:text !important;
      user-select:text !important;
    }
    .bubble{ cursor: pointer; position:relative; }
    /* Copy-on-click stays active, but no visible copy label (matches reference). */
    .bubble:hover::after{content:none !important;}


    .bubble.green{background:rgba(34,197,94,.10);border-color:rgba(34,197,94,.18)}
    .bubble.green .v{color:var(--green)}
    .bubble.red{background:rgba(239,68,68,.10);border-color:rgba(239,68,68,.18)}
    .bubble.red .v{color:var(--red)}
    .bubble.blue{background:rgba(148,163,184,.08);border-color:var(--border)}
    [data-theme="light"] .bubble.blue{background:#F3F4F6}
    .bubble.blue .v{color:var(--fg)}
    .bubble.blue .t, .bubble.blue .s{color:var(--muted)}

    /* Bubble text tinting (titles/subtitles) to match value color */

/* Bubble headers/info in same color family as values */
.bubble.green .tLabel, .bubble.green .s, .bubble.green .tRow{color:color-mix(in srgb, var(--green) 82%, var(--muted)) !important;}
.bubble.red   .tLabel, .bubble.red   .s, .bubble.red   .tRow{color:color-mix(in srgb, var(--red) 82%, var(--muted)) !important;}
.bubble.blue  .tLabel, .bubble.blue  .s, .bubble.blue  .tRow{color:color-mix(in srgb, var(--blue2) 85%, var(--muted)) !important;}

    .bubble.green .t, .bubble.green .s{color:color-mix(in srgb, var(--green) 75%, var(--muted));}
    .bubble.red .t, .bubble.red .s{color:color-mix(in srgb, var(--red) 75%, var(--muted));}
    .bubble.blue .t, .bubble.blue .s{color:color-mix(in srgb, var(--blue2) 80%, var(--muted));}

/* === Bubble text: neutral ONLY for gray/white bubbles (blue) === */
.bubble.blue .tRow{color:var(--fg) !important;}
.bubble.blue .tLabel{color:var(--fg) !important;}
.bubble.blue .s{color:var(--muted) !important;}

    .breakEven{
      display:flex;gap:12px;align-items:center;
      padding:14px;border-radius:16px;margin:12px 0 18px;
      background:rgba(34,197,94,.10);
      border:1px solid rgba(34,197,94,.18);
      animation:none;
    }
    .beIcon{
      width:40px;height:40px;border-radius:999px;
      background:var(--green);
      display:grid;place-items:center;color:#fff;
    }
    .beTitle{font-weight:800;color:color-mix(in srgb, var(--green) 85%, var(--fg));font-size:14px}
    .beSub{color:color-mix(in srgb, var(--green) 70%, var(--muted));font-size:12px;margin-top:3px}
    .numPos{color:var(--green);font-weight:700}
    .numNeg{color:var(--red);font-weight:700}
    .numMid{color:var(--yellow);font-weight:700}
    .tfoot{
      background:rgba(148,163,184,.06);
      box-shadow: inset 0 1px 0 rgba(255,255,255,0.06);
      border-top:3px solid color-mix(in srgb, var(--blue) 35%, var(--border));
    }
    /* Tooltips */
    .tip{position:relative;display:inline-flex;align-items:center}
    .tip button{
      border:0;background:transparent;color:var(--muted);
      padding:0;margin:0;cursor:help;display:inline-flex;align-items:center;justify-content:center
    }

    /* Bubble tooltip icon color should match bubble color */
    .bubble.green .tip button{ color: var(--green); }
    .bubble.red   .tip button{ color: var(--red); }
    .bubble.orange .tip button{ color: #F59E0B; }
    /* Neutral (gray/white) bubbles keep muted/neutral icon */
    .bubble.blue  .tip button{ color: var(--muted); }
    .tip .bubbleTip{
      position:absolute;left:50%;transform:translateX(-50%);
      top:20px;
      min-width:240px;max-width:360px;
      background:var(--card);
      border:1px solid var(--border);
      padding:10px 10px;border-radius:12px;
      color:var(--fg);
      font-size:12px;line-height:1.35;white-space:normal;
      box-shadow:var(--shadow);
      opacity:0;pointer-events:none;transition:opacity .12s ease, transform .12s ease;
      z-index:100;
    }
    .tip:hover .bubbleTip{opacity:1;transform:translateX(-50%) translateY(2px)}
    .tip.open .bubbleTip{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(2px)}
    /* TRL Helpers (match .html) */
.trl-help-icon{position:relative;display:inline-flex;align-items:center;justify-content:center;vertical-align:middle;margin-left:6px;color:var(--muted);cursor:help}
.trl-help-icon i{color:inherit}
body[data-theme="light"] .trl-help-icon{color:rgba(15,23,42,55)}
.trl-help-tooltip{
  position:fixed;z-index:9999;pointer-events:none;
  max-width:260px;
  transform:translateY(-50%);
  border-radius:12px;
  padding:10px 12px;
  font-size:14px;line-height:1.35;
  background:rgba(0,0,0,92);
  border:1px solid rgba(51,65,85,55);
  color:#fff;
  box-shadow:none;
}
body[data-theme="light"] .trl-help-tooltip{
  background:#ffffff;
  border-color:rgba(15,23,42,0.12);
  color:#0f172a;
  box-shadow:none;
}

/* Use TRL helper tooltip for ALL .tip tooltips (prevents "two formats") */
    .tip .bubbleTip{display:none !important;}

    
    .tip.open .bubbleTip{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(2px)}
    .tip.right.open .bubbleTip{opacity:1;pointer-events:auto;transform:translateY(2px)}

    /* Ensure tooltip stays above other bubbles/cards */
    .tip{z-index:1}
    .tip.open{z-index:999}
    .bubble{z-index:0}
    .bubble:hover{z-index:2}

    /* Mobile tooltip containment handled via JS positioning (no full-width fixed tooltips) */

    /* Mobile: tooltips should open/close instantly (no weird slide animation) */
    @media (max-width: 720px){
      /* Mobile: tooltips open/close instantly and ONLY via .open (disable sticky :hover on touch) */
      .tip .bubbleTip{transition:none !important;}
      .tip:hover .bubbleTip{opacity:0 !important;pointer-events:none !important;transform:translateX(-50%) !important;}
      .tip.open .bubbleTip{opacity:1 !important;pointer-events:auto !important;transform:translateX(-50%) !important;}
      /* Treat right-side tips the same on mobile (JS clamps + centers); avoid transform:none that breaks containment */
      .tip.right:hover .bubbleTip{opacity:0 !important;pointer-events:none !important;transform:translateX(-50%) !important;left:50% !important;right:auto !important;}
      .tip.right.open .bubbleTip{opacity:1 !important;pointer-events:auto !important;transform:translateX(-50%) !important;left:50% !important;right:auto !important;}
    }

/* Toast */
    .toasts{position:fixed;right:14px;bottom:14px;display:flex;flex-direction:column;gap:10px;z-index:200}
    .toast{
      background:rgba(2,6,23,.90);
      color:#fff;
      border:1px solid rgba(148,163,184,.18);
      padding:10px 12px;border-radius:14px;
      box-shadow:0 15px 35px rgba(0,0,0,.25);
      font-size:13px;display:flex;align-items:center;gap:10px;
      animation: toastIn .18s ease;
      max-width:min(360px, calc(100vw - 28px));
    }
    [data-theme="light"] .toast{
      background:#ffffff;
      color:#000000;
      border-color:rgba(0,0,0,.12);
    }
    @keyframes toastIn{from{transform:translateY(6px);opacity:.7}to{transform:translateY(0);opacity:1}}
    .hintRow{display:flex;align-items:center;gap:10px;justify-content:center;margin-bottom:12px}
    .hRight{display:flex;gap:10px;align-items:center}
    .small{font-size:12px}
    .nowrap{white-space:nowrap}
  
    
    /* Mobile add-row button placement (Partial Closes) */
    .ladderAddRowWrap{display:none}
    @media (max-width: 720px){
      .ladderAddRowWrap{
        display:flex;
        justify-content:flex-end;
        margin:10px 0 8px;
      }
    }

    /* ---- TRL auth CTA containers (hidden by prehide until auth resolves) ---- */
    .headerRight{display:flex;align-items:center;gap:12px}
    .headerCtas{display:flex;align-items:center;gap:10px}
    .mobileCtas{display:none;gap:10px;justify-content:flex-end;margin-top:10px}
    @media (max-width: 720px){
      .headerCtas{display:none}
      .mobileCtas{display:flex;flex-wrap:wrap}
    }

/* === FIXES (layout + controls) === */
    /* Fee settings modal */
.modalOverlay{
  position:fixed; inset:0;
  background:rgba(0,0,0,.55);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  display:none;
  align-items:center;
  justify-content:center;
  z-index:320;
  padding:16px;
}
body[data-theme="light"] .modalOverlay{background:rgba(15,23,42,.35);}
.modalOverlay.open{display:flex;}

.modalCard{
  position:relative; z-index:2;
  width:min(520px, 100%);
  background:var(--card);
  border:1px solid var(--border);
  border-radius:20px;
  box-shadow:var(--shadow);
  padding:20px;
}
.modalHead{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}
.modalTitle{margin:0;font-weight:900;font-size:16px}
.modalGrid{display:grid;gap:12px}
.modalRow{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.modalActions{display:flex;align-items:center;justify-content:flex-end;gap:10px;margin-top:6px}
@media (max-width: 520px){
  .modalRow{grid-template-columns:1fr}
}
@media (max-width: 420px){
  .modalActions{flex-direction:column;align-items:stretch}
}

/* Modal buttons: remove bulky frames for Close + Cancel */
#feeModalClose.btn{
  border:0 !important;
  outline:0 !important;
  box-shadow:none !important;
  background:transparent !important;
  padding:8px !important;
  border-radius:12px !important;
}
#feeModalClose.btn:focus,
#feeModalClose.btn:focus-visible{
  border:0 !important;
  outline:0 !important;
  box-shadow:none !important;
}
#feeModalClose.btn:hover{background:rgba(148,163,184,.12) !important;}
body[data-theme="light"] #feeModalClose.btn:hover{background:rgba(15,23,42,.06) !important;}

#feeModalCancel.btn{
  border:0 !important;
  outline:0 !important;
  box-shadow:none !important;
  background:rgba(148,163,184,.10) !important;
}
#feeModalCancel.btn:focus,
#feeModalCancel.btn:focus-visible{
  border:0 !important;
  outline:0 !important;
  box-shadow:none !important;
}
#feeModalCancel.btn:hover{background:rgba(148,163,184,.14) !important;}
body[data-theme="light"] #feeModalCancel.btn{
  background:rgba(15,23,42,.05) !important;
}
body[data-theme="light"] #feeModalCancel.btn:hover{
  background:rgba(15,23,42,.08) !important;
}



/* v11 tweaks: per-close toggle = icon only (no frame) */
#toggleSnapshots{
  padding:0 !important;
  border:0 !important;
  background:transparent !important;
  box-shadow:none !important;
  min-height:unset !important;
  border-radius:0 !important;
}
#toggleSnapshots{
  -webkit-appearance:none;
  appearance:none;
  outline:none;
}

#toggleSnapshots:hover{background:transparent !important; filter:brightness(1.08);}
#toggleSnapshots i{ width:18px !important; height:18px !important; }
/* Theme toggle: subtle outline */
#themeBtn.themeToggle{
  border:1px solid rgba(148,163,184,.22) !important;
  background:transparent !important;
  box-shadow:none !important;
  outline:none !important;
}
body[data-theme="light"] #themeBtn.themeToggle{
  border-color: rgba(15,23,42,.14) !important;
}
#themeBtn.themeToggle:hover{background:rgba(148,163,184,.12) !important;}
body[data-theme="light"] #themeBtn.themeToggle:hover{background:rgba(15,23,42,.06) !important;}

/* Dropdown: selected item should be bold, NOT blue; blue only on hover */
.trl-dd-item.selected{
  background:transparent !important;
  font-weight:800 !important;
}
.trl-dd-item.selected:hover{
  background:rgba(37,99,235,.18) !important;
}
body[data-theme="light"] .trl-dd-item.selected:hover{
  background:rgba(37,99,235,.14) !important;
}

/* Info boxes: shrink to content + center text */
#warnBox .warn{justify-content:center;align-items:center;text-align:center}
#warnBox .warn .small{text-align:center}

/* Break-even box: keep icon left, center text perfectly */
.breakEven{
  width:fit-content;
  max-width:100%;
  margin-left:auto;
  margin-right:auto;
  display:grid;
  grid-template-columns:40px 1fr 40px;
  align-items:center;
  gap:12px;
  text-align:center;
  justify-items:center;
}
.breakEven .beIcon{justify-self:start}
.breakEven .beText{justify-self:center}
.breakEven .beSpacer{width:40px;height:40px}
.breakEven .beTitle,.breakEven .beSub{text-align:center}


/* Per-close snapshots header toggle */
.btn.iconOnly{ padding:6px 8px; min-width:36px; display:flex; align-items:center; justify-content:center; }
.snapChevron{ transition: transform .15s ease; }
#toggleSnapshots.open .snapChevron, #toggleQuickStart.open .snapChevron{ transform: rotate(180deg); }
#snapshotsHeader:hover{ filter: brightness(1.05); }


/* Quick Start Guide: make bold text stand out */
body[data-theme="dark"] #quickStartBody b,
body[data-theme="dark"] #quickStartBody strong{ color:#ffffff; }
body[data-theme="light"] #quickStartBody b,
body[data-theme="light"] #quickStartBody strong{ color:#0f172a; }

/* Center the header text horizontally (match reference when folded) */
#snapshotsHeader{ position:relative; }
#snapshotsHeader h4{
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  margin:0;
  pointer-events:none; /* allow the whole header/card to be clickable */
}
#snapshotsHeader .hRight{ margin-left:auto; }

/* Make the whole Per-close snapshots card clickable when folded */
#stepSnapshotsCard{ cursor:pointer; }
#snapshotsBody{ cursor:default; }

/* ===== Per-close snapshots: background behind each bubble (do NOT change bubble colors) ===== */

/* ===== Per-close snapshots: force the WHOLE card/section background to #0E1117 (no #1A1F2E showing) ===== */
#snapshotsSection{
  background:#0E1117 !important;
}
#snapshotsSection.trlSectionPanel{
  background:#0E1117 !important;
}
#snapshotsSection .trlSectionInner{
  background:transparent !important;
}
#snapshotsSection #stepSnapshotsCard.card{
  background:#0E1117 !important;
}
#snapshotsSection #stepSnapshotsCard.card,
#snapshotsSection #stepSnapshotsCard.card *{
  /* Prevent any nested element from reintroducing the old card color */
  --card:#0E1117 !important;
}
#snapshotsSection #stepSnapshotsCard.card .card{
  background:#0E1117 !important;
}
#snapshotsSection #stepSnapshotsCard.card .tableWrap,
#snapshotsSection #stepSnapshotsCard.card .panel,
#snapshotsSection #stepSnapshotsCard.card .glass,
#snapshotsSection #stepSnapshotsCard.card .sheet{
  background:#0E1117 !important;
}

#snapshotsSection .bubbleCellBg{
  /* Background behind bubble only (no visible frame outside bubble) */
  background:#0E1117;
  border-radius:16px; /* match bubble rounding */
  padding:0;          /* remove outer frame */
  overflow:hidden;    /* clip bg to bubble bounds */
}
#snapshotsSection .bubbleCellBg > .bubble{
  width:100%;
  height:100%;
}


/* ===== Per-close snapshots: LIGHT MODE should be pure white (#FFFFFF) ===== */
body[data-theme="light"] #snapshotsSection{
  background:#FFFFFF !important;
}
body[data-theme="light"] #snapshotsSection.trlSectionPanel{
  background:#FFFFFF !important;
}
body[data-theme="light"] #snapshotsSection #stepSnapshotsCard.card{
  background:#FFFFFF !important;
}
body[data-theme="light"] #snapshotsSection #stepSnapshotsCard.card,
body[data-theme="light"] #snapshotsSection #stepSnapshotsCard.card *{
  --card:#FFFFFF !important;
}
body[data-theme="light"] #snapshotsSection #stepSnapshotsCard.card .card,
body[data-theme="light"] #snapshotsSection #stepSnapshotsCard.card .tableWrap,
body[data-theme="light"] #snapshotsSection #stepSnapshotsCard.card .panel,
body[data-theme="light"] #snapshotsSection #stepSnapshotsCard.card .glass,
body[data-theme="light"] #snapshotsSection #stepSnapshotsCard.card .sheet{
  background:#FFFFFF !important;
}
body[data-theme="light"] #snapshotsSection .bubbleCellBg{
  background:#FFFFFF !important;
}



/* Breakdown table: fixed rounded corners */
.tableWrap.breakdownWrap{overflow:hidden;border-radius:14px;}
.tableWrap.breakdownWrap table{border-radius:14px;overflow:hidden;}
.tableWrap.breakdownWrap thead th:first-child{border-top-left-radius:14px;}
.tableWrap.breakdownWrap thead th:last-child{border-top-right-radius:14px;}
.tableWrap.breakdownWrap tfoot td:first-child,
.tableWrap.breakdownWrap tfoot th:first-child{border-bottom-left-radius:14px;}
.tableWrap.breakdownWrap tfoot td:last-child,
.tableWrap.breakdownWrap tfoot th:last-child{border-bottom-right-radius:14px;}

/* Breakdown table: restore rounded corners like other tables */
.tableWrap.breakdownWrap{
  overflow:hidden;
  border-radius:14px;
}
.tableWrap.breakdownWrap table{
  border-radius:14px;
}

/* === Responsive polish (summary + per-close snapshots) === */



/* Breakdown table: highlight rows on hover + click (match html behavior) */
.tableWrap.breakdownWrap tbody tr{
  cursor:pointer;
  transition: background .12s ease;
}
.tableWrap.breakdownWrap tbody tr:hover td{
  background: rgba(59,130,246,0.06);
}
.tableWrap.breakdownWrap tbody tr.trl-row-selected td{
  background: rgba(59,130,246,0.10);
}
body[data-theme="light"] .tableWrap.breakdownWrap tbody tr:hover td{
  background: rgba(37,99,235,0.08);
}
body[data-theme="light"] .tableWrap.breakdownWrap tbody tr.trl-row-selected td{
  background: rgba(37,99,235,0.12);
}
/* Mobile: ladder table should not squeeze TP input; keep horizontal scroll and readable inputs */
@media (max-width: 720px){
  .tableWrap.ladderWrap .ladderTable{
    min-width: 720px;
  }
  .tableWrap.ladderWrap .ladderTable .input.mini{
    min-width: 130px;
    text-align:center;
  }
}
@media (max-width: 1100px){
  .grid.grid-4{ grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
}
@media (max-width: 520px){
  /* Mobile: bubbles in pairs (2 per row) + prevent value/title overflow */
  .grid.grid-4{ grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
  .bubble{ padding:12px !important; }

  /* Allow long titles and values to wrap instead of overflowing outside cards */
  .bubble .tLabel{ white-space:normal !important; line-height:1.15 !important; }
  .bubble .v{
    font-size:22px !important;
    line-height:1.12 !important;
    white-space:normal !important;
    overflow:hidden !important;
    text-overflow:clip !important;
    word-break:break-word !important;
  }
  .bubble .s{
    font-size:12px !important;
    white-space:normal !important;
    overflow:hidden !important;
    text-overflow:clip !important;
  }

  /* Keep existing helper classes if used elsewhere */
  .bubbleValue{ font-size:22px !important; line-height:1.12 !important; }
  .bubbleTitle{ font-size:13px !important; }
  .bubbleSub{ font-size:12px !important; }
}
/* prevent tooltip/icon overlap on narrow cards */
.bubbleHead{ min-height: 22px; }
.bubbleTitle{ padding-right: 22px; } /* room for ? icon */


    /* Desktop: subtle 'zoomed out' feel */
    

/* ===== Sectioned layout (like) ===== */
.trlSection{
  margin-top:16px;
  border-radius:22px;
}
.trlSectionInner{max-width:1600px;margin:0 auto;padding:0 16px;width:100%}
#snapshotsSection .trlSectionInner{max-width:1800px;}

.trlSectionBlack{
  background: var(--bg);
  border: 1px solid color-mix(in srgb, var(--border) 70%, transparent);
  box-shadow: var(--shadow);
}
.trlSectionBlack .trlSectionTitle{
  margin:0 0 12px;
  font-size:18px;
  font-weight:800;
}
.trlSectionPanel{
  background: color-mix(in srgb, var(--card) 92%, transparent);
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
}
.trlSectionPanel .card{
  margin-top:0 !important;
  box-shadow:none !important;
  border:0 !important;
  background:transparent !important;
  padding:0 !important;
}
#summarySection .sumSectionTitle{
  margin-left:0;
  margin-right:0;
}
@media (max-width: 720px){ .trlSectionInner{ padding:0 12px; } }


    
/* ===== Summary section headers (match style) ===== */
.kpiSection{margin-top:18px;}
.kpiSection:first-child{margin-top:4px;}
.kpiH2{
  margin:0 0 12px;
  font-size:26px;
  font-weight:900;
  letter-spacing:.2px;
  color:var(--fg);
}
body[data-theme="light"] .kpiH2{color:rgb(15 23 42);}
@media (max-width: 520px){
  .kpiH2{font-size:22px;}
}
/* Liquidation bubble (theme-aware like reference) */
    [data-theme="light"] .bubble.orange{
      background:#F9EDE3;
      border-color:rgba(245,158,11,.35);
    }
    [data-theme="dark"] .bubble.orange{
      background:rgba(245,158,11,.12);
      border-color:rgba(245,158,11,.22);
    }
    .bubble.orange .v{ color:#F59E0B; }
    .bubble.orange .tLabel,
    .bubble.orange .s,
    .bubble.orange .tRow{ color: color-mix(in srgb, #F59E0B 82%, var(--muted)) !important; }
    .bubble.orange .t{ color: color-mix(in srgb, #F59E0B 72%, var(--muted)); }

    /* === Bubble headers + info text: force neutral ONLY for gray/white bubbles (blue) === */
    .bubble.blue .tRow, .bubble.blue .tLabel{
      color: var(--fg) !important;
    }
    .bubble.blue .s{
      color: var(--muted) !important;
    }


/* Light mode: zero-value gray bubbles should match neutral 'Fees' bubble scheme */
body[data-theme="light"] .bubble.gray{
  background:#F3F4F6 !important;
  border-color: rgba(15,23,42,.10) !important;
}
body[data-theme="light"] .bubble.gray .v{
  color:#0f172a !important;
}
body[data-theme="light"] .bubble.gray .tRow,
body[data-theme="light"] .bubble.gray .tLabel{
  color:#0f172a !important;
}
body[data-theme="light"] .bubble.gray .s{
  color: rgb(71 85 105) !important;
}


/* ===== Bubble copyability (like ) =====
   Allow selecting/copying numeric values directly from bubbles.
   Keep copy-on-click (handled in JS) but do not block text selection.
*/
.bubble,
.bubble *{
  user-select:text !important;
  -webkit-user-select:text !important;
}



/* ===== Summary sectioning (match ) ===== */
#summarySection .sumSection{ margin-top: 10px; }
#summarySection .sumSectionTitle{
  font-weight: 700;
  letter-spacing: .2px;
  font-size: 14px;
  color: rgba(232,238,249,.78);
  margin: 6px 4px 10px;
  display:flex;
  align-items:center;
  gap:10px;
}
#summarySection .sumSectionTitle:after{
  content:'';
  height:1px;
  flex:1;
  background: linear-gradient(90deg, rgba(255,255,255,.12), transparent);
}
#summarySection .trlSectionTitle{
  margin:0 0 12px;
  font-size:18px;
  font-weight:800;
}



/* ===== Summary width alignment: match input section card width ===== */
#summarySection .trlSectionInner{padding-left:16px !important;padding-right:16px !important;}
@media (max-width: 720px){ #summarySection .trlSectionInner{ padding-left:12px !important; padding-right:12px !important; } }



#summarySection .kpiSection{
  /* Match the same inner width as the main input + snapshots cards */
  padding-left:0;
  padding-right:0;
}


/* ===== Header spacing: match html (do NOT zero out padding) ===== */
#site-header .max-w-7xl{max-width:80rem !important;} /* tailwind max-w-7xl */
#site-header .mx-auto{margin-left:auto !important;margin-right:auto !important;}
#site-header .px-6{padding-left:1.5rem !important;padding-right:1.5rem !important;}
@media (min-width: 1024px){
  #site-header .lg\:px-8{padding-left:2rem !important;padding-right:2rem !important;}
}

/* ===== v11 (requested) FIX: Per-close snapshots header should be taller like reference (zdj4) ===== */
#snapshotsHeader{
  padding-top:16px !important;
  padding-bottom:16px !important;
  min-height:58px !important;
}
@media (max-width: 720px){
  #snapshotsHeader{
    padding-top:12px !important;
    padding-bottom:12px !important;
    min-height:52px !important;
  }
}



/* ===== v12 (requested) TWEAKS: ladder table slightly wide (but not full-card) + snapshots header slightly less tall ===== */

/* Per-close snapshots header: reduce height slightly vs v11 (still taller than original) */
#snapshotsHeader{
  padding-top:14px !important;
  padding-bottom:14px !important;
  min-height:54px !important;
}
@media (max-width: 720px){
  #snapshotsHeader{
    padding-top:10px !important;
    padding-bottom:10px !important;
    min-height:48px !important;
  }
}


/* ===== v13 (requested) FIXES: ladder table NOT too wide + snapshots header slightly less tall + spacing under breakdown ===== */

/* Per-close snapshots header: slightly less tall than v12 */
#snapshotsHeader{
  padding-top:12px !important;
  padding-bottom:12px !important;
  min-height:50px !important;
}
@media (max-width: 720px){
  #snapshotsHeader{
    padding-top:9px !important;
    padding-bottom:9px !important;
    min-height:44px !important;
  }
}

/* Add page breathing room UNDER the whole Breakdown section (NOT inside the table/card) */
#breakdownSection{
  margin-bottom: 18px !important;
}
#breakdownSection .card{
  padding-bottom: 0 !important;
  margin-bottom: 0 !important;
}




/* ===== Bubble copyability (requested) =====
   Allow selecting/copying numeric values directly from bubbles (double click / click+drag).
*/
.bubble,
.bubble *{
  -webkit-user-select: text !important;
  user-select: text !important;
}
.bubble{ cursor: text !important; }




      /* ---- TRL header (copied from html) ---- */
      #site-header {
        zoom: 1.111111;
        background: rgba(26,31,46,0.92);
        backdrop-filter: blur(18px);
        -webkit-backdrop-filter: blur(18px);
        border-bottom: 1px solid rgba(30,64,175,0.45);
      }
      #site-header.header-scrolled {
        background: rgba(26,31,46,0.96);
        box-shadow: 0 18px 45px rgba(15,23,42,0.95);
        border-bottom-color: rgba(37,99,235,0.7);
      }
    
      /* Theme-aware header colors (only for top bar) */
      body[data-theme="light"] #site-header{
        background: rgba(255,255,255,0.86);
        backdrop-filter: blur(18px);
        -webkit-backdrop-filter: blur(18px);
        border-bottom: 1px solid rgba(37,99,235,0.22);
      }
      body[data-theme="light"] #site-header.header-scrolled{
        background: rgba(255,255,255,0.92);
        box-shadow: 0 18px 45px rgba(15,23,42,0.12);
        border-bottom-color: rgba(37,99,235,0.35);
      }
      body[data-theme="light"] #site-header .text-slate-300{ color: rgb(51 65 85) !important; }
      body[data-theme="light"] #site-header .text-slate-400{ color: rgb(71 85 105) !important; }
      body[data-theme="light"] #site-header .text-slate-200{ color: rgb(15 23 42) !important; }
      body[data-theme="light"] #site-header a[href="/"] span.text-white{ color: rgb(15 23 42) !important; }

      body[data-theme="light"] #site-header .hover\:text-white:hover{ color: rgb(15 23 42) !important; }
      body[data-theme="light"] #site-header .hover\:bg-white\/5:hover{ background: rgba(15,23,42,0.04) !important; }
      body[data-theme="light"] #site-header .text-white{ color: rgb(15 23 42) !important; }

      /* Light mode: keep desktop Log out text white inside gradient button */
      body[data-theme="light"] #site-header #header-logout-desktop,
      body[data-theme="light"] #site-header #header-logout-desktop *{
        color: #ffffff !important;
      }
      body[data-theme="light"] #site-header .bg-slate-900\/95{ background: rgba(255,255,255,0.96) !important; }
      body[data-theme="light"] #site-header .border-slate-800{ border-color: rgba(15,23,42,0.10) !important; }


      /* Theme-aware MOBILE side panel (off-canvas menu) */
      body[data-theme="light"] #mobile-menu .bg-slate-900{ background: rgba(255,255,255,0.96) !important; }
      body[data-theme="light"] #mobile-menu .border-slate-800{ border-color: rgba(15,23,42,0.10) !important; }
      body[data-theme="light"] #mobile-menu .border-slate-700{ border-color: rgba(15,23,42,0.14) !important; }
      body[data-theme="light"] #mobile-menu nav .text-slate-300{ color: rgb(15 23 42) !important; }
      body[data-theme="light"] #mobile-menu nav .text-white{ color: rgb(15 23 42) !important; }
      body[data-theme="light"] #mobile-menu nav .hover\:text-white:hover{ color: rgb(15 23 42) !important; }
      body[data-theme="light"] #mobile-menu nav .hover\:bg-white\/5:hover{ background: rgba(15,23,42,0.04) !important; }

      body[data-theme="light"] #mobile-menu #trl-mobile-cta{ border-top-color: rgba(15,23,42,0.10) !important; }
      body[data-theme="light"] #mobile-menu #trl-mobile-cta a[href="/account-settings"]{
        color: rgb(15 23 42) !important;
        border-color: rgba(15,23,42,0.14) !important;
      }
      body[data-theme="light"] #mobile-menu #trl-mobile-cta a[href="/account-settings"]:hover{
        background: rgba(15,23,42,0.06) !important;
      }

      /* Page entrance overlay (render everything together) */
      .page-transition-overlay{
        position: fixed;
        inset: 0;
        background-color: #0E1117;
        opacity: 0;
        pointer-events: none;
        transition: opacity 170ms cubic-bezier(0.22, 1, 0.36, 1);
        z-index: 9999;
      }
      .page-transition-overlay.is-active{
        opacity: 1;
        pointer-events: auto;
      }
      body[data-theme="light"] .page-transition-overlay{
        background-color: #f8fafc;
      }

      /* Light mode: keep logo + Log out text white inside */
      body[data-theme="light"] #trl-logo-link .text-white{ color: #ffffff !important; }
      body[data-theme="light"] #header-logout-desktop,
      body[data-theme="light"] #header-logout-mobile{ color: #ffffff !important; }
      /* Light mode: keep desktop Log out text white inside (override any utility classes) */
      body[data-theme="light"] #header-logout-desktop,
      body[data-theme="light"] #header-logout-desktop:hover,
      body[data-theme="light"] #header-logout-desktop:focus{ color: #ffffff !important; }

      /* Light mode: mobile menu - keep Dashboard label black even if it is the current/active page */
      body[data-theme="light"] #mobile-menu a[href="/dashboard"],
      body[data-theme="light"] #mobile-menu a[href="/dashboard"][aria-current="page"]{
        color: #0f172a !important;
        opacity: 1 !important;
      }


#trl-desktop-cta,#trl-mobile-cta{visibility:hidden}

/* Generated classes moved from inline style attributes for CSP cleanup. */
.pcx-style-1{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.pcx-style-2{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap;margin-bottom:12px}
.pcx-style-3{width:16px;height:16px}
.pcx-style-4{margin-bottom:18px}
.pcx-style-5{margin-bottom:16px}
.pcx-style-6{font-size:18px;font-weight:800}
.pcx-style-7{width:14px;height:14px}
.pcx-style-8{margin-bottom:14px}
.pcx-style-9{display:none}
.pcx-style-10{display:none;margin-bottom:14px}
.pcx-style-11{margin-bottom:10px;}
.pcx-style-12{margin:0;font-size:16px;font-weight:800}
.pcx-style-13{margin:0}
.pcx-style-14{margin-top:12px;}
.pcx-style-15{overflow-x:auto}
.pcx-style-16{width:70px}
.pcx-style-17{width:86px}
.pcx-style-18{width:260px}
.pcx-style-19{width:92px}
.pcx-style-20{margin-bottom:12px}
.pcx-style-21{margin-bottom:10px}
.pcx-style-22{margin-top:16px;}
.pcx-style-23{margin-bottom:10px; cursor:pointer; user-select:none;}
.pcx-style-24{font-size:16px;font-weight:800;margin-bottom:12px}
.pcx-style-25{text-align:center;width:60px}
.pcx-style-26{text-align:center}
.pcx-style-27{grid-column:1/-1}
.pcx-style-28{display:inline-flex;align-items:center;gap:6px}
.pcx-style-29{margin-top:8px}
.pcx-style-30{display:flex;align-items:flex-start;gap:10px;margin-top:12px}
.pcx-style-31{margin:3px 0 0 0;display:inline-block}
.pcx-style-32{min-width:0}
.pcx-style-33{margin:0;font-weight:700;display:flex;align-items:center;gap:6px}
.pcx-style-34{margin-top:12px}
.pcx-style-35{margin-top:14px}
.pcx-style-36{grid-column:1/-1;display:flex;align-items:flex-start;gap:10px}

/* Theme-aware page scrollbars (match Scenarios/Risk of Ruin/Multiple Entries behavior) */
html[data-theme="dark"], body[data-theme="dark"] {
  scrollbar-width: thin;
  scrollbar-color: #334155 #0E1117;
}
html[data-theme="light"], body[data-theme="light"] {
  scrollbar-width: thin;
  scrollbar-color: #cbd5e1 #f8fafc;
}
html[data-theme="dark"] ::-webkit-scrollbar,
body[data-theme="dark"] ::-webkit-scrollbar { width: 10px; height: 10px; }
html[data-theme="dark"] ::-webkit-scrollbar-track,
body[data-theme="dark"] ::-webkit-scrollbar-track { background: #0E1117; }
html[data-theme="dark"] ::-webkit-scrollbar-thumb,
body[data-theme="dark"] ::-webkit-scrollbar-thumb {
  background: #334155;
  border-radius: 999px;
  border: 2px solid #0E1117;
}
html[data-theme="dark"] ::-webkit-scrollbar-thumb:hover,
body[data-theme="dark"] ::-webkit-scrollbar-thumb:hover { background: #475569; }
html[data-theme="light"] ::-webkit-scrollbar,
body[data-theme="light"] ::-webkit-scrollbar { width: 10px; height: 10px; }
html[data-theme="light"] ::-webkit-scrollbar-track,
body[data-theme="light"] ::-webkit-scrollbar-track { background: #f8fafc; }
html[data-theme="light"] ::-webkit-scrollbar-thumb,
body[data-theme="light"] ::-webkit-scrollbar-thumb {
  background: #cbd5e1;
  border-radius: 999px;
  border: 2px solid #f8fafc;
}
html[data-theme="light"] ::-webkit-scrollbar-thumb:hover,
body[data-theme="light"] ::-webkit-scrollbar-thumb:hover { background: #94a3b8; }

/* Saved-theme prepaint support */
html[data-theme="light"] body { color-scheme: light; }
html[data-theme="dark"] body { color-scheme: dark; }
html[data-theme="light"] .page-transition-overlay{ background-color:#f8fafc; }
html[data-theme="dark"] .page-transition-overlay{ background-color:#0E1117; }

/* Light-mode copy toast should match reference tools */
html[data-theme="light"] .toast,
body[data-theme="light"] .toast{
  background:#ffffff !important;
  color:#0f172a !important;
  border-color:rgba(15,23,42,.12) !important;
  box-shadow:0 15px 35px rgba(15,23,42,.16) !important;
}
html[data-theme="light"] .toast svg,
body[data-theme="light"] .toast svg{ color:#0f172a !important; }

.toastIcon{width:16px;height:16px;flex:0 0 auto;}

.pcx-text-center{text-align:center;}
.pcx-total-label{text-align:left;font-weight:800;padding-left:14px;}
.pcx-fw800{font-weight:800;}
.pcx-fw900{font-weight:900;}
.pcx-icon14{width:14px;height:14px;}
.pcx-icon16{width:16px;height:16px;}
.pcx-icon20{width:20px;height:20px;}
.pcx-icon-flex{flex:0 0 auto;}
.pcx-icon-red{color:var(--red);}

/* Mobile side menu auth layout (matches Trading Journal exactly) */
#mobile-menu #header-logout-mobile{
  margin-top:10px;
}
@media (max-width:1023px){
  #mobile-menu #trl-mobile-cta{
    display:flex;
    flex-direction:column;
    gap:12px;
  }
}

/* Partial Closes mobile menu overlay/auth fix: keep side menu identical to Trading Journal and never visually locked/dimmed. */
#mobile-menu,
#mobile-menu .trl-mobile-backdrop,
#mobile-menu .trl-mobile-panel,
#mobile-menu .trl-mobile-panel *{
  filter:none !important;
  -webkit-filter:none !important;
}

#mobile-menu .trl-mobile-panel,
#mobile-menu .trl-mobile-panel nav,
#mobile-menu .trl-mobile-panel nav a,
#mobile-menu #trl-mobile-cta,
#mobile-menu #trl-mobile-cta a,
#mobile-menu #header-logout-mobile{
  opacity:1 !important;
  filter:none !important;
  -webkit-filter:none !important;
  pointer-events:auto !important;
}

#mobile-menu #trl-mobile-cta a[aria-disabled="true"],
#mobile-menu #trl-mobile-cta a[data-trl-disabled],
#mobile-menu #trl-mobile-cta a.trl-tool-input-locked,
#mobile-menu .trl-mobile-panel .trl-tool-input-locked{
  opacity:1 !important;
  filter:none !important;
  -webkit-filter:none !important;
  cursor:pointer !important;
  pointer-events:auto !important;
}

#mobile-menu #header-logout-mobile,
#mobile-menu #header-logout-mobile:visited,
#mobile-menu #header-logout-mobile:hover,
#mobile-menu #header-logout-mobile:focus{
  color:#ffffff !important;
  -webkit-text-fill-color:#ffffff !important;
  opacity:1 !important;
  filter:none !important;
  -webkit-filter:none !important;
  background-image:linear-gradient(to right, rgb(37 99 235), rgb(6 182 212)) !important;
  box-shadow:0 10px 18px rgba(59,130,246,.25) !important;
}

body[data-theme="dark"] #mobile-menu #trl-mobile-cta a:not(#header-logout-mobile),
html[data-theme="dark"] #mobile-menu #trl-mobile-cta a:not(#header-logout-mobile){
  color:#ffffff !important;
  -webkit-text-fill-color:#ffffff !important;
  opacity:1 !important;
}

body[data-theme="dark"] #mobile-menu .trl-mobile-panel nav a,
html[data-theme="dark"] #mobile-menu .trl-mobile-panel nav a{
  color:rgb(203 213 225) !important;
  -webkit-text-fill-color:rgb(203 213 225) !important;
  opacity:1 !important;
}

body[data-theme="dark"] #mobile-menu .trl-mobile-panel nav a:hover,
html[data-theme="dark"] #mobile-menu .trl-mobile-panel nav a:hover{
  color:#ffffff !important;
  -webkit-text-fill-color:#ffffff !important;
}
