: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:1.0; /* compact view (like 90% zoom) */
    }
    a{color:inherit}
    .container{max-width:1400px;margin:0 auto;padding:96px 16px 24px}
    .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:hidden;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:6px 0 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}
    }
    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}

    
/* 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:hidden;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:center}
.ladderStack{display:flex;flex-direction:column;align-items:stretch;gap:10px;max-width:100%}
.ladderStack .tableWrap.ladderWrap{align-self:center}
#warnBox{width:fit-content;max-width:100%;align-self:center;margin:0 auto}
/* 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:hidden;
    }
    table{width:100%;border-collapse:collapse;font-size:13px}
    .breakdownTable{font-size:15px}
    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: don't stretch across the whole card (remove empty middle space) */
    .tableWrap.ladderWrap{
      display:inline-block;
      width:auto;
      max-width:100%;
      zoom:1.20;
    }
    .tableWrap.ladderWrap .ladderTable{
      width:auto;
      min-width:1120px;
    }
    @media (max-width: 980px){
      .tableWrap.ladderWrap{display:block;width:100%;zoom:1;}
      .tableWrap.ladderWrap .ladderTable{width:100%;min-width:0;}
    }
    .ladderTable thead th{
      text-align:center;
      font-size:13px;
      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;
      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}
    .ladderTable .colActions{width:92px;text-align:center}
    .ladderTable .input.mini{height:40px;border-radius:12px;text-align:center}
    .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:min(520px, 100%);}
    .ladder-close{width:min(220px, 100%);}

    .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 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)}
    .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:hidden;
    }
    [data-theme="light"] .bubble{background:#F3F4F6}
    .bubble:hover{transform:none;border-color:color-mix(in srgb, var(--blue) 45%, var(--border))}
    .bubble .t{font-size:13px;color:var(--muted);margin-bottom:4px;display:flex;align-items:center;gap:8px}
    .bubble .v{font-size:24px;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
    .bubble .s{font-size:13px;color:var(--muted);margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
    .bubble.is-copyable:focus-visible{
      outline:2px solid color-mix(in srgb, var(--blue) 70%, transparent);
      outline-offset:2px;
    }
    .bubble .copyMark{display:none !important;}
    .ror-copy-fallback{
      position:fixed;
      left:-9999px;
      top:-9999px;
      opacity:0;
      pointer-events:none;
    }

    .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 scheme: make blue bubbles neutral gray/white like Fees () === */
    /* Match Fees bubble: neutral background, white title, subtle blue subtitle */
    .bubble.blue{background:rgba(148,163,184,.08);border-color:var(--border)}
    [data-theme="light"] .bubble.blue{background:#F3F4F6;border-color:var(--border)}
    /* Prevent the global hover from tinting border blue (Fees bubble stays neutral) */
    .bubble.blue:hover{border-color:var(--border) !important;background:rgba(148,163,184,.08) !important;}
    [data-theme="light"] .bubble.blue:hover{border-color:var(--border) !important;background:#F3F4F6 !important;}

    /* Title + value */
    .bubble.blue .t{color:var(--fg) !important;}
    .bubble.blue .v{color:var(--fg) !important;}

    /* Subtitle (matches Fees screenshots: slightly blue-leaning) */
    [data-theme="dark"] .bubble.blue .s{color:#94A3B8E6 !important;}
    [data-theme="light"] .bubble.blue .s{color:#000000 !important;}

    /* Tooltip icon should follow bubble tone */
    .bubble.blue  .trl-help-icon{color:var(--fg) !important;}
    .bubble.green .trl-help-icon{color:color-mix(in srgb, var(--green) 82%, var(--muted)) !important;}
    .bubble.red   .trl-help-icon{color:color-mix(in srgb, var(--red) 82%, var(--muted)) !important;}
    .bubble.orange .trl-help-icon{color:color-mix(in srgb, var(--yellow) 82%, var(--muted)) !important;}


    /* Bubble text tinting (titles/subtitles) to match value color */
    .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:var(--muted)}
    .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
    }
    .tip .bubbleTip{
      position:absolute;left:50%;transform:translateX(-50%);
      top:20px;
      min-width:220px;max-width:280px;
      background:color-mix(in srgb, var(--card) 92%, #000 0%);
      border:1px solid var(--border);
      padding:10px 10px;border-radius:12px;
      color:var(--fg);
      font-size:12px;line-height:1.35;
      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)}
    /* 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,
    body[data-theme="light"] .toast{
      background:#ffffff;
      color:#0f172a;
      border-color:rgba(15,23,42,.12);
      box-shadow:0 15px 35px rgba(15,23,42,.14);
    }
    @keyframes toastIn{from{transform:translateY(6px);opacity:.7}to{transform:translateY(0);opacity:1}}
    .toast.hidden{display:none !important;}
    .toast.show{display:flex;}
    .hintRow{display:flex;align-items:center;gap:10px;justify-content:space-between;margin-bottom:12px}
    .hRight{display:flex;gap:10px;align-items:center}
    .small{font-size:12px}
    .nowrap{white-space:nowrap}
  
    /* ---- 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}
    }


    /* 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:12px;line-height:1.35;
      background:rgba(0,0,0,.92);
      border:1px solid rgba(51,65,85,.55);
      color:#fff;
      box-shadow:0 12px 30px rgba(0,0,0,.35);
    }
    body[data-theme="light"] .trl-help-tooltip{
      background:#ffffff;
      border-color:rgba(15,23,42,0.12);
      color:#0f172a;
      box-shadow:0 10px 24px rgba(15,23,42,.10);
    }

/* === FIXES (layout + controls) === */

/* Theme toggle: subtle outline */

/* Theme toggle (match .html outline button) */
#themeBtn.themeToggle{
  height:36px;width:36px;
  border-radius:10px;
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid rgba(55,65,81,1) !important; /* gray-700 */
  background:#0E1117 !important;
  color:#fff !important;
}
#themeBtn.themeToggle:hover{ background:rgba(255,255,255,.10) !important; }
body[data-theme="light"] #themeBtn.themeToggle{
  border-color: rgba(209,213,219,1) !important; /* gray-300 */
  background:transparent !important;
  color:rgba(2,6,23,.85) !important;
}
body[data-theme="light"] #themeBtn.themeToggle:hover{ background:rgba(15,23,42,.06) !important; }

#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}


    /* 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{
  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;
}
/* Mobile usability */
@media (max-width: 720px){
  body{zoom:1;}
  .container{padding:88px 12px 20px;}
  .hintRow{flex-wrap:wrap;gap:10px;}
  .hRight{flex-wrap:wrap;}
}


/* Mobile-only layouts (do not affect desktop) */
#summaryMobile{display:none;}
.ladderMobile{display:none;}
.breakdownMobile{display:none;}
.ladderMobileAddWrap{display:none;margin-top:10px;} /* shown only on mobile */

/* Mobile breakdown (transposed) */
.breakdownTransposeWrap{
  border:1px solid var(--border);
  border-radius:14px;
  overflow:hidden;
}
.breakdownTranspose{
  width:100%;
  border-collapse:collapse;
  font-size:14px;
}
.breakdownTranspose th,
.breakdownTranspose td{
  padding:10px 12px;
  border-top:1px solid color-mix(in srgb, var(--border) 92%, transparent);
  vertical-align:middle;
  text-align:center;
}
.breakdownTranspose thead th{
  border-top:none;
  background:rgba(148,163,184,.10);
  font-weight:800;
}
[data-theme="light"] .breakdownTranspose thead th{background:#f1f5f9;}
.breakdownTranspose th.rowLabel{
  text-align:left;
  font-weight:800;
  color:color-mix(in srgb, var(--fg) 78%, transparent);
  background:rgba(148,163,184,.06);
}
[data-theme="light"] .breakdownTranspose th.rowLabel{background:#f8fafc;}
.breakdownTranspose td.mutedCell{color:var(--muted);}

@media (max-width: 720px){
  /* Projections table: use stacked cards instead of squeezed table */
  .tableWrap.ladderWrap{display:none !important;}
  .ladderMobile{display:block;}

  
/* Mobile: move Add entry under the latest leg (desktop button stays unchanged) */
#addExit{display:none !important;}
.ladderMobileAddWrap{display:block;}
#mobileAddExit{width:100%;justify-content:center;}

/* Mobile breakdown: show vertical/transposed view */
#breakdownDesktopWrap{display:none !important;}
.breakdownMobile{display:block;}
.breakdownTransposeWrap{overflow-x:auto;}
.ladderMobileCard{
    background:rgba(148,163,184,.06);
    border:1px solid var(--border);
    border-radius:16px;
    padding:12px;
    margin-bottom:12px;
  }
  [data-theme="light"] .ladderMobileCard{background:#f8fafc;}
  .ladderMobileTop{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
  .ladderMobileLeft{display:flex;align-items:center;gap:10px;min-width:0}
  .ladderMobileActions{display:flex;align-items:center;gap:10px}
  .ladderMobileGrid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
  .ladderMobileGrid .field{min-width:0}
  .ladderMobileGrid .span2{grid-column:1 / -1}
  .ladderMobileGrid label{font-size:12px;margin-bottom:6px}
  .ladderMobileGrid .input{height:44px;font-size:15px;border-radius:14px;text-align:center}

  /* Summary bubbles: show paired grid */
  #summaryTop,#summaryBottom{display:none !important;}
  #summaryMobile{
    display:grid !important;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:12px;
    margin-bottom:10px;
  }

  /* Breakdown: readable via horizontal scroll + larger cells */
  .breakdownTable{min-width:820px;}
  .breakdownTable th, .breakdownTable td{padding:12px 10px;}
}

@media (min-width: 721px){
  #summaryMobile{display:none !important;}
}

/* === Projections KPI bubbles: neutral background + orange liquidation === */
    .bubble{background:rgba(148,163,184,.08);}
    [data-theme="light"] .bubble{background:#F3F4F6;}
    [data-theme="light"] .bubble.blue{background:#F3F4F6;border-color:var(--border);}
    [data-theme="light"] .bubble.green{background:#E3F5EB;border-color:rgba(34,197,94,.22);}
    [data-theme="light"] .bubble.red{background:#F8E8E8;border-color:rgba(239,68,68,.22);}
    [data-theme="light"] .bubble.orange{background:#F9EDE3;border-color:rgba(245,158,11,.24);}
    .bubble:hover{transform:none;border-color:color-mix(in srgb, var(--border) 80%, transparent);}
    .bubble .v.pos{color:var(--green);}
    .bubble .v.neg{color:var(--red);}
    .bubble.orange{background:rgba(245,158,11,.10);border-color:rgba(245,158,11,.22)}
    .bubble.orange .v{color:var(--yellow)}
    .bubble.orange .t, .bubble.orange .s{color:color-mix(in srgb, var(--yellow) 75%, var(--muted));}



    /* Light mode: match 'Statistical Observations & Analysis' background to bubble light gray */
    [data-theme="light"] .obsCard{
      background:#ffffff;
    }

    /* Light mode: Observations section should be white, with each paragraph box in light gray (#F3F4F6) */
    .obsPanel{
      padding:14px 16px;
      border-radius:14px;
      background:rgba(0,0,0,.16);
      border:1px solid rgba(148,163,184,.10);
    }
    body[data-theme="light"] .obsPanel{
      background:#F3F4F6;
      border-color: rgba(15,23,42,0.10);
    }

/* Add purple used by comparison mode (matches screenshots) */

#modeInputsModeled .formRow3 + .formRow3{margin-top:14px}
:root{ --purple:#a855f7; --purple2:#7c3aed; }

/* Layout tweaks specific to Risk of Ruin */
main{max-width:1280px;margin:0 auto;padding:92px 18px 64px;}
.card{padding:22px 22px 24px;border-radius:22px;}
.h1{font-size:20px;font-weight:900;margin:0;}
.sub{margin-top:6px;color:var(--muted);font-size:13px}

.formGrid{display:grid;grid-template-columns:1fr;gap:14px;margin-top:16px}
.formRow3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.formRow2{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
@media(max-width:920px){.formRow3{grid-template-columns:1fr}.formRow2{grid-template-columns:1fr}}

.field label{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--fg);font-weight:700;margin:0 0 8px}
.input{width:100%}
.runRow{margin-top:16px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.btnPrimary{display:inline-flex;align-items:center;gap:10px;padding:11px 16px;border-radius:10px;
  border:1px solid rgba(59,130,246,.35); background:var(--blue); color:#fff; font-weight:900;
  box-shadow: 0 12px 26px rgba(37,99,235,.22); cursor:pointer; user-select:none}
.btnPrimary:active{transform:translateY(1px)}
.btnPrimary[disabled]{opacity:.6;cursor:not-allowed}
.btnPrimary svg{width:18px;height:18px}


/* --- Simulation model selector + mode-specific input blocks --- */
.modeBar{
  margin-top:12px;
  border-radius:14px;
  border:1px solid color-mix(in srgb, var(--blue2) 22%, var(--border));
  background: color-mix(in srgb, var(--blue2) 10%, transparent);
  padding:12px 14px;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  flex-wrap:wrap;
}
.modeLabel{display:flex;align-items:center;gap:10px;font-weight:900;color:color-mix(in srgb, var(--blue2) 78%, var(--fg));}
.modeSeg{display:flex;gap:8px;flex-wrap:wrap;align-items:flex-end}
.modeBtn{padding:7px 12px;border-radius:10px;font-size:13px;border:0 !important;background:rgba(148,163,184,.10)}
[data-theme="light"] .modeBtn{background:rgba(15,23,42,.05)}
.modeBtn:hover{background:rgba(148,163,184,.14)}
[data-theme="light"] .modeBtn:hover{background:rgba(15,23,42,.08)}
.modeBtn.active{background:var(--blue) !important;color:#fff !important}
.modeHint{margin-top:10px;color:var(--muted);font-size:12.5px;line-height:1.45}
.modeGroupTitle{margin-top:12px;color:color-mix(in srgb, var(--blue2) 70%, var(--fg));font-size:11px;font-weight:900;letter-spacing:.10em;text-transform:uppercase}

/* Charts */
.chartGrid{display:grid;grid-template-columns:1.6fr 1fr;gap:14px;align-items:start}
.chartCol{display:grid;gap:14px;align-content:start}
@media(max-width:1100px){.chartGrid{grid-template-columns:1fr}}
.chartCard{padding:16px 16px 14px}
.chartHead{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px}
.chartHead .title{font-weight:900}
.chartHead .sub{margin:2px 0 0;color:var(--muted);font-size:12.5px;line-height:1.35}
.chartCanvasWrap{border:1px solid var(--border);border-radius:14px;background:rgba(0,0,0,.12);padding:10px}
[data-theme="light"] .chartCanvasWrap{background:#f8fafc}
.chartCanvasWrap canvas{width:100% !important;height:360px !important}
@media(max-width:520px){.chartCanvasWrap canvas{height:280px !important}}

.compBar{margin-top:18px;border-radius:14px;border:1px solid color-mix(in srgb, var(--blue2) 28%, var(--border));
  background: color-mix(in srgb, var(--blue2) 14%, transparent); padding:14px 16px;
  display:flex;align-items:center;justify-content:space-between;gap:14px}
.compLabel{display:flex;align-items:center;gap:10px;font-weight:900;color:color-mix(in srgb, var(--blue2) 75%, var(--fg));}

/* Switch styled like TRL controls */
.trl-switch{position:relative;width:44px;height:24px;flex:0 0 auto}
.trl-switch input{position:absolute;inset:0;opacity:0;cursor:pointer}
.trl-switch .track{position:absolute;inset:0;border-radius:999px;background:rgba(148,163,184,.35);
  border:1px solid color-mix(in srgb, var(--border) 70%, transparent); transition:background .15s ease,border-color .15s ease}
.trl-switch .thumb{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:999px;background:#fff;transition:transform .15s ease}
.trl-switch input:checked ~ .track{background: color-mix(in srgb, var(--blue2) 70%, #000 0%); border-color: color-mix(in srgb, var(--blue2) 55%, var(--border))}
.trl-switch input:checked ~ .thumb{transform:translateX(20px)}

.sectionTitle{margin:28px 0 14px;font-size:20px;font-weight:900}
.bubbles{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media(max-width:1100px){.bubbles{grid-template-columns:repeat(2,1fr)}}
@media(max-width:720px){.bubbles{grid-template-columns:repeat(2,1fr)}}
@media(max-width:420px){.bubbles{grid-template-columns:repeat(2,1fr);gap:12px}}
.bubbles5{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}

.bubbles3{grid-template-columns:repeat(3,1fr)}
@media(max-width:1100px){.bubbles3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.bubbles3{grid-template-columns:1fr}}
.modeOption{display:flex;flex-direction:column;align-items:center;gap:6px}
.modeOption .modeTip{opacity:.85}
.modeOption .modeTip:hover{opacity:1}

@media(max-width:1200px){.bubbles5{grid-template-columns:repeat(2,1fr)}}
@media(max-width:720px){.bubbles5{grid-template-columns:repeat(2,1fr)}}
@media(max-width:420px){.bubbles5{grid-template-columns:repeat(2,1fr);gap:12px}}

.bubble.red{background:color-mix(in srgb, var(--red) 10%, transparent);border-color:color-mix(in srgb, var(--red) 22%, var(--border))}
.bubble.green{background:color-mix(in srgb, var(--green) 10%, transparent);border-color:color-mix(in srgb, var(--green) 22%, var(--border))}
.bubble.blue{background:rgba(148,163,184,.08);border-color:var(--border)}

.bubble.red .v{color:var(--red)} .bubble.green .v{color:var(--green)} .bubble.blue .v{color:var(--fg)}
.bubble.red .t{color:color-mix(in srgb, var(--red) 75%, var(--muted))}
.bubble.green .t{color:color-mix(in srgb, var(--green) 75%, var(--muted))}
.bubble.blue .t{color:var(--fg)}


.hidden{display:none}

.comparePanel{margin-top:14px;border-radius:16px;border:1px solid var(--border);background:rgba(148,163,184,.06);padding:14px}
.comparePanel h3{margin:0 0 10px;font-size:16px}
.compInputs{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media(max-width:980px){.compInputs{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.compInputs{grid-template-columns:1fr}}

.compCard{margin-top:18px;border-radius:18px;border:1px solid var(--border);background:rgba(148,163,184,.06);overflow:hidden}
.compHead{padding:16px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:10px;cursor:pointer}
.compHead h3{margin:0;font-size:16px}
.compHead .small{font-size:12px;color:var(--muted);margin-top:4px}
.compBody{padding:16px}
.compScenarioGrid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px}
@media(max-width:720px){.compScenarioGrid{grid-template-columns:1fr 1fr}}
@media(max-width:420px){.compScenarioGrid{grid-template-columns:1fr 1fr}}
.scA{border:1px solid color-mix(in srgb, var(--blue2) 25%, var(--border));background:color-mix(in srgb, var(--blue2) 10%, transparent);border-radius:12px;padding:12px}
.scB{border:1px solid color-mix(in srgb, var(--purple2) 25%, var(--border));background:color-mix(in srgb, var(--purple2) 10%, transparent);border-radius:12px;padding:12px}
.scA .k{color:color-mix(in srgb, var(--blue2) 80%, var(--fg));font-weight:900;font-size:13px}
.scB .k{color:color-mix(in srgb, var(--purple) 80%, var(--fg));font-weight:900;font-size:13px}
.scA .d,.scB .d{font-size:12px;color:var(--muted);margin-top:4px}

.compTable{display:flex;flex-direction:column;gap:10px}
.compRow{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px;border-radius:12px;background:rgba(0,0,0,.14);border:1px solid rgba(148,163,184,.10)}
[data-theme="light"] .compRow{background:#f8fafc;border-color:#e5e7eb}
.compRow .m{font-size:13px;font-weight:800;color:color-mix(in srgb, var(--fg) 90%, var(--muted))}
.compRow .vals{display:flex;align-items:center;gap:10px;font-weight:900}
.compRow .vs{font-size:12px;color:var(--muted);font-weight:700}
.compRow .a{min-width:74px;text-align:right}
.compRow .b{min-width:74px;text-align:left}
.good{color:var(--green)} .bad{color:var(--red)} .neutral{color:var(--fg)} .tie{color:color-mix(in srgb, var(--blue2) 85%, var(--fg))}


@media(max-width:520px){
  /* Keep comparison rows readable on small screens */
  .compRow{flex-direction:column;align-items:stretch;gap:8px}
  .compRow .vals{justify-content:space-between}
  .compRow .a,.compRow .b{min-width:0}
}
/* --- Requested fixes: non-clickable bubbles + strategy comparison light backgrounds + chart controls --- */
.bubble{cursor:default; user-select:none;}
.bubble *{user-select:none;}
.bubble .trl-help-icon{cursor:help;}
.bubble .trl-help-icon *{user-select:none;}

/* Bubble helper icons: align all to the top-right corner (inside bubble) */
.bubble .trl-help-icon{
  position:absolute;
  top:12px;
  right:12px;
  margin-left:0 !important;
}
.bubble .t{padding-right:28px;}

/* Strategy Comparison: whole section white, inner blocks light gray (#F3F4F6) in light mode */
body[data-theme="light"] .comparePanel{background:#ffffff;}
body[data-theme="light"] .compCard{background:#ffffff;}
body[data-theme="light"] .compBody{background:#ffffff;}
body[data-theme="light"] .scA,
body[data-theme="light"] .scB{background:#F3F4F6;border-color:rgba(15,23,42,0.12);}
body[data-theme="light"] .compRow{background:#F3F4F6;border-color:rgba(15,23,42,0.10);}



/* --- Strategy Comparison layout polish (compact, easier to scan) --- */
.comparePanel{padding:12px}
/* Make the whole Strategy Comparison section narrower but centered */
#comparisonCard{max-width:980px;margin-left:auto;margin-right:auto;width:100%;}

.comparePanel h3{margin:0 0 8px;font-size:16px}
.compCard{border-radius:16px}
.compHead{padding:14px 16px}
.compBody{padding:12px 14px}
.compScenarioGrid{gap:10px;margin-bottom:10px}
.scA,.scB{padding:10px;border-radius:12px}
.compTable{display:flex;flex-direction:column;gap:8px}

/* Use a grid row so labels and values stay compact on wide screens */
.compRow{
  display:grid;
  grid-template-columns:minmax(180px,1fr) 110px 30px 110px;
  align-items:center;
  gap:10px;
  padding:10px 12px;
  border-radius:14px;
}
.compRow .m{font-size:13px;font-weight:800;line-height:1.25;margin:0}
.compRow .vals{display:contents}
.compRow .a,.compRow .b{min-width:0;text-align:right;font-weight:900}
.compRow .b{text-align:left}
.compRow .vs{font-size:12px;color:var(--muted);font-weight:800;text-align:center}

/* Smaller screens: keep it readable without giant gaps */
@media(max-width:720px){
  .compRow{grid-template-columns:minmax(150px,1fr) 90px 26px 90px;padding:10px}
}
@media(max-width:480px){
  .compRow{grid-template-columns:1fr;gap:6px}
  .compRow .a,.compRow .b{display:inline-block;text-align:left}
  .compRow .vs{display:none}
  .compRow .a::before{content:"A: ";color:var(--muted);font-weight:800}
  .compRow .b::before{content:"B: ";color:var(--muted);font-weight:800}
}

/* --- Strategy Comparison (NEW presentation: compact matrix) --- */
.compMatrix{display:grid;gap:8px;margin-top:10px}
.compMatrixHead{
  display:grid;
  grid-template-columns:minmax(160px,1.4fr) minmax(90px,1fr) 16px minmax(90px,1fr) minmax(70px,.7fr);
  gap:10px;
  padding:8px 12px;
  border-radius:12px;
  background:rgba(0,0,0,.10);
  border:1px solid rgba(148,163,184,.10);
  font-size:12px;
  font-weight:900;
  color:var(--muted);
}
[data-theme="light"] .compMatrixHead{background:#F3F4F6;border-color:rgba(15,23,42,0.10)}
.compMatrixHead .hA{color:color-mix(in srgb, var(--blue2) 80%, var(--fg));text-align:center}
.compMatrixHead .hB{color:color-mix(in srgb, var(--purple) 80%, var(--fg));text-align:center}
.compMatrixHead .hD{text-align:center}
.cmpRow{
  display:grid;
  grid-template-columns:minmax(160px,1.4fr) minmax(90px,1fr) 16px minmax(90px,1fr) minmax(70px,.7fr);
  gap:10px;
  align-items:center;
  padding:10px 12px;
  border-radius:14px;
  background:rgba(0,0,0,.14);
  border:1px solid rgba(148,163,184,.10);
}
.cmpRow{
  transition: background .15s ease, border-color .15s ease, box-shadow .15s ease, transform .15s ease;
}
[data-theme="dark"] .cmpRow:hover{
  background: rgba(59,130,246,.10);
  border-color: rgba(59,130,246,.26);
  box-shadow: 0 0 0 1px rgba(59,130,246,.10), 0 18px 40px rgba(0,0,0,.22);
  transform: translateY(-1px);
}
[data-theme="light"] .cmpRow:hover{
  background: #E8F1FF;
  border-color: rgba(59,130,246,.26);
  box-shadow: 0 0 0 1px rgba(59,130,246,.10);
  transform: translateY(-1px);
}

/* Comparison score pills (Scenario A/B header) */
.scScore{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-top:6px}
.scorePill{
  display:inline-flex;align-items:center;justify-content:center;
  height:22px;padding:0 10px;border-radius:999px;
  font-size:12px;font-weight:900;letter-spacing:.02em;
  border:1px solid rgba(148,163,184,.18);
  background:rgba(148,163,184,.10);
  color:var(--muted);
}
.scorePill.blue{background:rgba(59,130,246,.12);border-color:rgba(59,130,246,.22);color:var(--blue2)}
.scorePill.purple{background:rgba(168,85,247,.12);border-color:rgba(168,85,247,.22);color:var(--purple)}
[data-theme="light"] .scorePill{background:#F3F4F6;border-color:rgba(15,23,42,.12);color:#111827}
[data-theme="light"] .scorePill.blue{background:#E8F1FF;border-color:rgba(59,130,246,.22);color:#1d4ed8}
[data-theme="light"] .scorePill.purple{background:#F4E9FF;border-color:rgba(168,85,247,.22);color:#6d28d9}
[data-theme="light"] .cmpRow{background:#F3F4F6;border-color:rgba(15,23,42,0.10)}
.cmpMetric{font-size:13px;font-weight:900;line-height:1.2;color:color-mix(in srgb, var(--fg) 92%, var(--muted))}

.cmpColon{font-size:12px;font-weight:900;color:var(--muted);text-align:center;}
.cmpVal{
  font-size:13px;
  font-weight:900;
  text-align:center;
  font-variant-numeric:tabular-nums;
  white-space:nowrap;
}
.cmpDelta{display:flex;align-items:center;justify-content:center}
.cmpBadge{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:34px;
  height:22px;
  padding:0 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
  border:1px solid rgba(148,163,184,.18);
  background:rgba(148,163,184,.10);
  color:var(--muted);
}
.cmpBadge.good{background:rgba(34,197,94,.14);border-color:rgba(34,197,94,.24);color:var(--green)}
.cmpBadge.bad{background:rgba(239,68,68,.14);border-color:rgba(239,68,68,.24);color:var(--red)}
.cmpBadge.tie{background:rgba(59,130,246,.14);border-color:rgba(59,130,246,.26);color:color-mix(in srgb, var(--blue2) 85%, var(--fg))}
@media(max-width:720px){
  /* Mobile comparison results: centered metric + A : B + Better badge */
  .compMatrixHead{display:none}
  .compMatrix{grid-template-columns:1fr 1fr;}
  .compMatrix > .cmpRow{height:100%;}
  /* If odd number of metrics, let the last one span full width for balance */
  
  .cmpRow{
    grid-template-columns:1fr 16px 1fr;
    grid-template-areas:
      "metric metric metric"
      "aval colon bval"
      "badge badge badge";
    gap:8px;
    padding:10px 12px;
    justify-items:stretch;
  }
  .cmpMetric{grid-area:metric;text-align:center}
  .cmpRow .cmpVal.aVal{grid-area:aval;text-align:right}
  .cmpRow .cmpVal.bVal{grid-area:bval;text-align:left}
  .cmpColon{grid-area:colon;display:flex;align-items:center;justify-content:center}
  .cmpDelta{grid-area:badge; display:flex;justify-content:center}

  /* Scenario tiles stay side-by-side on mobile */
  .compScenarioGrid{grid-template-columns:1fr 1fr}
}
@media(max-width:420px){
  /* Extra-small screens: keep A/B pairs side-by-side */
  .compMatrix{grid-template-columns:1fr 1fr;}
  .cmpRow{padding:10px 10px;gap:6px;}
  .cmpMetric{font-size:12px}
  .cmpVal{font-size:12px}
  .cmpColon{font-size:11px}
  .cmpBadge{height:20px;min-width:32px;font-size:11px;padding:0 8px}
}

.trl-modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:1000;}
    .trl-modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:1001;padding:16px;}
    .trl-modal-panel{max-width:42rem;width:100%;border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.45);}
    button,[role="button"]{pointer-events:auto;}
  
    /* --- TRL theme helpers (only what is necessary for requested fixes) --- */
    [data-theme="dark"] .trl-btn-outline{border-color:#374151;color:#e5e7eb;}
    [data-theme="light"] .trl-btn-outline{border-color:#d1d5db;color:#111827;}
    [data-theme="dark"] .trl-btn-outline:hover{background:rgba(255,255,255,.10);box-shadow:0 0 0 1px rgba(255,255,255,.06),0 0 14px rgba(59,130,246,.10);}
    [data-theme="light"] .trl-btn-outline:hover{background:rgba(0,0,0,.05);}


    /* Dialog close button color per theme (Symbol Settings) */
    [data-theme="dark"] .trl-dialog-close{color:#9ca3af;}
    [data-theme="dark"] .trl-dialog-close:hover{color:#ffffff;}
    [data-theme="light"] .trl-dialog-close{color:#111827;}
    [data-theme="light"] .trl-dialog-close:hover{color:#111827;}


    /* Native select styling + arrow visibility + move arrow inward */
    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");
    }


  
    /* Consistent focus ring (inside element so it won't get clipped by overflow-hidden parents) */
    [data-theme="dark"] input:focus,
    [data-theme="dark"] select:focus,
    [data-theme="dark"] textarea:focus{
      outline: 2px solid rgba(59,130,246,.40);
      outline-offset: -2px;
      box-shadow: none;
      border-color: rgba(59,130,246,.55);
    }
    [data-theme="light"] input:focus,
    [data-theme="light"] select:focus,
    [data-theme="light"] textarea:focus{
      outline: 2px solid rgba(59,130,246,.35);
      outline-offset: -2px;
      box-shadow: none;
      border-color: rgba(59,130,246,.55);
    }


    /* Disable focus outlines for the Category combo input (requested) */
    input.trl-no-focus:focus{
      outline: none !important;
      outline-offset: 0 !important;
      box-shadow: none !important;
      border-color: inherit !important;
    }

/* Switch colors (Light mode: OFF = light gray, ON = blue) */
    [data-theme="light"] .trl-switch-track:not(.bg-blue-600){
      background:#e5e7eb;
      border-color:#d1d5db;
    }

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

/* ---- TRL header (copied from ) ---- */
      #site-header {
        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;
      }



/* Mobile side-menu auth area — matches Trading Journal/Scenarios layout */
#mobile-menu #trl-mobile-cta.trl-mobile-auth-area{
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 12px !important;
}

#mobile-menu #trl-mobile-cta .trl-mobile-auth-row{
  width: 100% !important;
  display: block !important;
  padding: 12px 16px !important;
  border: 0 !important;
  border-radius: 8px !important;
  background: transparent !important;
  box-shadow: none !important;
  text-align: left !important;
  justify-content: flex-start !important;
  font-size: 16px !important;
}

#mobile-menu #trl-mobile-cta .trl-mobile-auth-button{
  width: 100% !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin-top: 4px !important;
}

body[data-theme="light"] #mobile-menu #trl-mobile-cta .trl-mobile-auth-row{
  color: rgb(15 23 42) !important;
}
body[data-theme="light"] #mobile-menu #trl-mobile-cta .trl-mobile-auth-row:hover{
  color: rgb(15 23 42) !important;
  background: rgba(15,23,42,0.04) !important;
}
body[data-theme="light"] #mobile-menu #trl-mobile-cta .trl-mobile-auth-button,
body[data-theme="light"] #mobile-menu #trl-mobile-cta .trl-mobile-auth-button *{
  color: #ffffff !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;
      }

      /* ===== FIX: ensure desktop header nav renders (Risk of Ruin) =====
         If responsive utility overrides fail to apply for any reason, the
         navigation/CTAs can remain hidden even on desktop. Force them visible
         at desktop widths while keeping the auth CTA visibility logic intact.
      */
      @media (min-width: 1024px){
        #site-header nav{ display:flex !important; }
        #site-header #trl-desktop-cta{ display:flex !important; }
        #mobile-menu-toggle{ display:none !important; }
      }

/* Inline style attributes moved from risk-of-ruin.html */

.ror-inline-1{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}

.ror-inline-2{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap;margin-bottom:12px;}

.ror-inline-3{width:16px;height:16px;}

.ror-inline-4{width:14px;height:14px;}

.ror-inline-5{height:auto;min-height:120px;resize:vertical;}

.ror-inline-6{}

.ror-inline-7{margin-top:18px;padding:0;overflow:hidden;}

.ror-inline-8{padding:16px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;color:color-mix(in srgb, var(--blue2) 75%, var(--fg));font-weight:900;}

.ror-inline-9{width:26px;height:26px;border-radius:10px;background:rgba(59,130,246,.18);display:inline-flex;align-items:center;justify-content:center;}

.ror-inline-10{padding:16px 20px;}

.ror-inline-11{padding:14px 18px;border-top:1px solid var(--border);color:var(--muted);font-size:12.5px;}


/* CSP cleanup helper classes moved from inline style attributes / JS templates */
.ror-icon-theme{width:16px;height:16px;}
.ror-icon-help{width:14px;height:14px;}
.ror-obs-grid{display:grid;gap:14px;}
.ror-obs-heading{margin:0 0 10px;font-weight:800;}
.ror-obs-heading-green{margin:0 0 10px;font-weight:800;color:var(--green);}
.ror-obs-list{margin:0;padding-left:18px;display:grid;gap:8px;line-height:1.45;}
.ror-text-red-strong{color:var(--red);font-weight:800;}


/* Theme-aware scrollbars: keep dark mode unchanged; make light mode scrollbars light */
html[data-theme="light"],
body[data-theme="light"]{
  scrollbar-color:#cbd5e1 #f8fafc;
}

html[data-theme="light"]::-webkit-scrollbar,
body[data-theme="light"]::-webkit-scrollbar,
body[data-theme="light"] *::-webkit-scrollbar{
  width:12px;
  height:12px;
}

html[data-theme="light"]::-webkit-scrollbar-track,
body[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,
body[data-theme="light"] *::-webkit-scrollbar-thumb{
  background:#cbd5e1;
  border:3px solid #f8fafc;
  border-radius:999px;
}

html[data-theme="light"]::-webkit-scrollbar-thumb:hover,
body[data-theme="light"]::-webkit-scrollbar-thumb:hover,
body[data-theme="light"] *::-webkit-scrollbar-thumb:hover{
  background:#94a3b8;
}


/* === Risk of Ruin theme preload parity with Scenarios ===
   The saved theme is applied to <html> before first paint. These selectors
   make the preloaded html theme control the visible page before body JS finishes. */
html[data-theme="light"] body{
  background:#f8fafc;
  color:#0f172a;
}
html[data-theme="dark"] body{
  background:#0E1117;
  color:#ffffff;
}
html[data-theme="light"] .page-transition-overlay{
  background-color:#f8fafc;
}
html[data-theme="dark"] .page-transition-overlay{
  background-color:#0E1117;
}
html[data-theme="light"] #themeBtn.themeToggle{
  border-color:rgba(15,23,42,.14) !important;
  background:transparent !important;
  color:rgba(2,6,23,.85) !important;
}
html[data-theme="light"] #themeBtn.themeToggle:hover{
  background:rgba(15,23,42,.06) !important;
}
html[data-theme="light"] #trl-logo-link .text-white,
html[data-theme="light"] #header-logout-desktop,
html[data-theme="light"] #header-logout-mobile{
  color:#ffffff !important;
}
html[data-theme="light"] .chartCanvasWrap{
  background:#f8fafc;
}
html[data-theme="light"] .trl-help-icon{
  color:rgba(15,23,42,.55);
}
html[data-theme="light"] .trl-help-tooltip{
  background:#ffffff;
  border-color:rgba(15,23,42,0.12);
  color:#0f172a;
  box-shadow:0 10px 24px rgba(15,23,42,.10);
}
