:root{
  --red:#B8231C;--red-d:#8E1A15;--ink:#211F1D;--charcoal:#262524;--gold:#C9A227;--gold-d:#A8861A;
  --green:#2C7A4B;--paper:#FBF8F3;--card:#FFFFFF;--line:#E7E0D4;--mute:#6F6A63;--soft:#F3EEE4;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:"Pretendard",-apple-system,"Apple SD Gothic Neo","Malgun Gothic",sans-serif;background:var(--paper);color:var(--ink);line-height:1.5;-webkit-font-smoothing:antialiased;font-variant-numeric:tabular-nums;overflow-x:hidden}
.num{font-variant-numeric:tabular-nums}
a{color:inherit}
button{font-family:inherit;cursor:pointer;border:none;border-radius:11px;font-weight:800;font-size:17px;box-shadow:0 2px 5px -2px rgba(0,0,0,.18);transition:filter .15s,background .15s,transform .08s,box-shadow .15s}
button:active{transform:translateY(1px);box-shadow:0 1px 2px -1px rgba(0,0,0,.18)}
button:hover{box-shadow:0 5px 12px -4px rgba(0,0,0,.22)}
input,select{font-family:inherit;font-size:20.5px;width:100%;padding:11px 13px;border:1.5px solid var(--line);border-radius:11px;background:#fff;color:var(--ink);font-variant-numeric:tabular-nums;box-shadow:0 2px 4px -2px rgba(0,0,0,.12);-webkit-appearance:none;appearance:none}
input:focus,select:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 3px rgba(184,35,28,.1)}
input:not([readonly]):not([type=checkbox]):hover,select:hover{border-color:#D9633B;box-shadow:0 5px 12px -4px rgba(0,0,0,.2)}
input:not([readonly]):not([type=checkbox]):focus:hover,select:focus:hover{border-color:var(--red);box-shadow:0 0 0 3px rgba(184,35,28,.12)}
input[readonly],.subgroup input[readonly]{
  background-color:#E7E3DA;color:#857e72;font-style:italic;box-shadow:none;
  border:1.5px solid #CFC6B4;cursor:default;
  background-image:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20width='11'%20height='11'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23a39b8a'%20stroke-width='2.6'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Crect%20x='5'%20y='11'%20width='14'%20height='9'%20rx='2'/%3E%3Cpath%20d='M8%2011V7a4%204%200%200%201%208%200v4'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:left 11px center;padding-left:31px;
}
input[readonly]:focus,.subgroup input[readonly]:focus{box-shadow:none;border-color:#CFC6B4}
.robadge{display:inline-block;font-size:14.5px;font-weight:800;color:#8a8276;background:#E7E3DA;border:1px solid #CFC6B4;border-radius:20px;padding:2px 9px;margin-left:7px;vertical-align:middle;letter-spacing:0;text-transform:none}
input[type=checkbox]{appearance:none;-webkit-appearance:none;width:18px;height:18px;padding:0;flex:0 0 auto;margin:0;border:1.6px solid #C9C0AF;border-radius:3px;background:#fff;cursor:pointer;position:relative;box-shadow:none;transition:background .12s,border-color .12s}
input[type=checkbox]:checked{background:var(--red);border-color:var(--red)}
input[type=checkbox]:checked::after{content:"";position:absolute;left:5px;top:1.5px;width:4px;height:9px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}
input[type=checkbox]:focus{outline:none;box-shadow:0 0 0 3px rgba(184,35,28,.15)}
.remember{display:flex;align-items:center;gap:8px;margin:-2px 0 15px;font-size:18.5px;font-weight:600;color:#46423d;cursor:pointer}

/* topbar */
.top{background:linear-gradient(160deg,#2E2B28,#1B1917);color:#fff;padding:14px 18px;display:flex;align-items:center;gap:12px;position:relative}
.top:before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:var(--red)}
.top .brand{font-size:16px;font-weight:800;letter-spacing:.14em;color:var(--gold)}
.top .who{margin-left:auto;font-size:18px;color:#D9D2C5;display:flex;align-items:center;gap:10px}
.top .who b{color:#fff}
.top .who button{background:rgba(255,255,255,.12);color:#fff;font-size:16px;padding:7px 12px}
.top .who button:hover{background:rgba(255,255,255,.22)}

.wrap{max-width:1080px;margin:0 auto;padding:20px}
.card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:20px;box-shadow:0 10px 30px -22px rgba(0,0,0,.25)}
.card+.card{margin-top:16px}
h2.sec{font-size:16px;font-weight:800;letter-spacing:.12em;color:var(--red);text-transform:uppercase}
.h2ko{font-size:24.5px;font-weight:800;margin:2px 0 16px}
.field{margin-bottom:13px}
label{display:block;font-size:18px;font-weight:700;color:#46423d;margin-bottom:6px}
label .hint{font-weight:500;color:var(--mute);font-size:15.5px;margin-left:6px}
.inrow{position:relative;display:flex;align-items:center}
.inrow .unit{position:absolute;right:13px;font-size:18px;color:var(--mute);font-weight:600;pointer-events:none}
.inrow input{padding-right:34px;min-width:0}
.two{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:11px;align-items:stretch}
.two>div{display:flex;flex-direction:column;min-width:0}
.two>div .inrow{margin-top:auto}
.three{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:11px}
.btn-red{background:var(--red);color:#fff;padding:13px}
.btn-red:hover{filter:brightness(1.07)}
.btn-ghost{background:var(--soft);color:var(--ink);padding:13px}
.btn-ghost:hover{background:#e9e2d4}
.btn-dark{background:var(--charcoal);color:#fff;padding:13px}
.btns{display:flex;gap:10px;margin-top:16px}
.btns button{font-size:19px;padding:16px}
.authtabs{display:flex;border-bottom:2px solid var(--line);margin-bottom:20px}
.authtabs button{box-shadow:none}
.authtab{flex:1;text-align:center;padding:12px 0;font-size:18px;font-weight:800;color:var(--mute);background:none;border:none;border-radius:0;border-bottom:3px solid transparent;margin-bottom:-2px}
.authtab.on{color:var(--red);border-bottom-color:var(--red)}
.center{max-width:460px;margin:6vh auto 0}

/* role cards */
.roles{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:18px}
@media(max-width:620px){.roles{grid-template-columns:1fr}}
.role{border:1.5px solid var(--line);border-radius:16px;padding:24px;text-align:center;background:#fff;cursor:pointer;box-shadow:0 5px 14px -9px rgba(0,0,0,.3);transition:border-color .15s,box-shadow .15s,transform .12s}
.role:active{transform:translateY(1px)}
.role:hover{border-color:var(--red);box-shadow:0 12px 28px -20px rgba(184,35,28,.5)}
.role .ic{width:54px;height:54px;border-radius:14px;background:var(--soft);display:flex;align-items:center;justify-content:center;margin:0 auto 12px;font-size:35.5px}
.role h3{font-size:23.5px;font-weight:800}
.role p{font-size:17px;color:var(--mute);margin-top:6px}

/* subgroup (cost) */
.subgroup{border:1.5px solid var(--line);border-radius:13px;padding:15px;background:var(--soft);margin-bottom:13px}
.sg-title{font-size:18.5px;font-weight:800;color:#46423d;margin-bottom:12px}
#costForm h2.sec{font-size:21px;margin-top:24px}
#costForm h2.sec:first-child{margin-top:0}
#costForm .subgroup{margin-bottom:12px}
#costForm .subgroup .two,#costForm .subgroup .three{margin-top:7px}
#costForm .sg-title{font-size:24px}
.sg-title .hint{font-weight:500;color:var(--mute);font-size:15.5px;margin-left:6px}
.sublabel{font-size:16px;font-weight:600;color:#5a554e;margin-bottom:5px}
.subgroup input{background:#fff;padding:10px 33px 10px 11px;font-size:19px}
.subgroup .two,.subgroup .three{margin-top:11px}
.subtotal{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-top:13px;padding-top:12px;border-top:1.5px dashed #D8CEBC}
.subtotal .st-l{font-size:18px;font-weight:800;flex:none}
.subtotal .st-v{font-size:23.5px;font-weight:800;color:var(--red);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:right}
.subtotal .st-pct{font-size:16px;font-weight:700;color:var(--mute);margin-left:9px}
.drow{display:flex;align-items:center;gap:9px;margin-top:9px}
.drow .nm{flex:0 0 auto;min-width:48px;white-space:nowrap;font-size:17px;font-weight:700;color:#5a554e}
.drow .inrow{flex:1}
.drow .del{flex:0 0 auto;background:none;color:var(--mute);font-size:24.5px;padding:4px 9px;border-radius:8px}
.drow .del:hover{background:#fff;color:var(--red)}
.addbtn{margin-top:11px;width:100%;background:#fff;color:var(--red);border:1.5px dashed var(--red);padding:10px;font-size:18px}
.addbtn:hover{background:#FCEFEE}
.ro-note{font-size:15.5px;color:var(--mute);margin-top:6px}

/* result */
.result{background:linear-gradient(165deg,#2E2B28,#1B1917);color:#fff;border:none}
.result .lbl{font-size:16px;letter-spacing:.1em;color:#BDB4A6;font-weight:700;text-transform:uppercase}
.profit{font-size:38px;font-weight:800;color:var(--gold);margin:4px 0 2px;white-space:nowrap;overflow:hidden}
.profitline{display:flex;align-items:flex-end;gap:14px;flex-wrap:wrap;margin:4px 0 2px}
.profitline .profit{margin:0}
.pdelta{font-size:15.5px;font-weight:800;white-space:nowrap;padding-bottom:5px}
.pdelta .pd-cap{color:#A89F90;font-weight:700;font-size:13.5px}
.pdelta.up .pd-val{color:#7FC99B}
.pdelta.down .pd-val{color:#E8897F}
.pdelta.flat .pd-val{color:#BDB4A6}
.profit.neg{color:#FF8A80}
.margin{font-size:19px;color:#D8D0C4}
.margin b{color:#fff}
.divider{height:1px;background:rgba(255,255,255,.12);margin:16px 0}
.sumrow{display:flex;justify-content:space-between;align-items:baseline;gap:10px;padding:5px 0;font-size:18.5px;color:#E4DDD2}
.sumrow>span:first-child{flex:none}
.sumrow .v{font-weight:700;color:#fff;flex:1;min-width:0;text-align:right;white-space:nowrap;overflow:hidden}
.sumrow.tot{border-top:1px solid rgba(255,255,255,.12);margin-top:4px;padding-top:10px;font-weight:800}
.sumrow.tot .v{color:var(--gold)}
.grid2{display:grid;grid-template-columns:1.15fr .85fr;gap:16px;align-items:start}
@media(max-width:880px){.grid2{grid-template-columns:1fr}}
.donut{width:120px;height:120px;border-radius:50%;-webkit-mask:radial-gradient(circle 36px at center,transparent 98%,#000 100%);mask:radial-gradient(circle 36px at center,transparent 98%,#000 100%)}
.donut-wrap{display:flex;gap:16px;align-items:center;flex-wrap:wrap;margin-top:6px}
.legend{flex:1;min-width:140px;display:flex;flex-direction:column;gap:4px}
.lg{display:flex;align-items:center;gap:7px;font-size:16px;color:#E4DDD2}
.lg .sw{width:10px;height:10px;border-radius:3px}
.lg .v{margin-left:auto;font-weight:700;color:#fff}

/* status badges */
.badge{display:inline-block;font-size:15.5px;font-weight:800;padding:3px 9px;border-radius:20px}
.b-pending{background:#EeE7DA;color:#8a8170}
.b-editing{background:#FFF0D6;color:#9a6f12}
.b-submitted{background:#DDF0E4;color:#1f6b40}

/* table */
.tablewrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:18.5px}
th,td{padding:11px 9px;text-align:right;border-bottom:1px solid var(--line);white-space:nowrap}
th:first-child,td:first-child{text-align:left}
th{font-size:15.5px;letter-spacing:.03em;color:var(--mute);font-weight:800;text-transform:uppercase}
td .pf{font-weight:800;color:var(--green)}
td .pf.neg{color:var(--red)}
td .warn{color:var(--red);font-weight:800}
.scard{border:1px solid var(--line);border-radius:13px;padding:13px 14px;margin-bottom:10px;background:#fff}
.scard.subm{cursor:pointer;border-color:#E6C9C6;box-shadow:0 9px 22px -11px rgba(184,35,28,.5),0 2px 6px -2px rgba(0,0,0,.12);transition:transform .12s,box-shadow .12s}
.scard.subm:hover{transform:translateY(-2px);box-shadow:0 14px 28px -11px rgba(184,35,28,.6),0 3px 8px -2px rgba(0,0,0,.14)}
.scard.subm:active{transform:translateY(0)}
.scard-anico{width:18px;height:18px;flex:none}
.scard-tap{margin-top:9px;font-size:12.5px;color:#B8231C;font-weight:700;text-align:center;opacity:.85}
.pop-analysis{max-width:460px;max-height:88vh;overflow-y:auto}
.pop-h{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:14px}
.pop-nm{font-size:20px;font-weight:800}
.pop-mo{font-size:13.5px;color:var(--mute);font-weight:700;margin-top:2px}
.pop-sum{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--line)}
.pop-sum>div{min-width:0;text-align:center}
.pop-sec{margin-bottom:16px}
.pop-sech{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px;font-size:14.5px;font-weight:800;color:var(--ink)}
.pop-sech .pop-sub{font-size:11.5px;font-weight:600;color:#A89F90}
.pop-sech .mg-legend{font-size:12px}
.pop-donut{background:linear-gradient(165deg,#2E2B28,#1B1917);border-radius:14px;padding:18px;color:#fff}
.pop-btns{display:flex;gap:10px}
.pop-close{flex:1;background:#fff;color:var(--charcoal);border:1.5px solid var(--charcoal);padding:13px;font-size:16px;font-weight:800;border-radius:11px}
.pop-close:hover{background:var(--charcoal);color:#fff}
.pop-detail{flex:1;background:var(--red);color:#fff;border:none;padding:13px;font-size:16px;font-weight:800;border-radius:11px}
.pop-detail:hover{filter:brightness(1.07)}
.bd-wrap{margin-top:2px}
.bd-sec{background:#FAF6EC;border:1px solid var(--line);border-radius:12px;padding:11px 13px 7px;margin-bottom:10px}
.bd-h{display:flex;justify-content:space-between;align-items:baseline;gap:10px;border-bottom:1.5px solid #E7DEC9;padding-bottom:7px;margin-bottom:6px}
.bd-h>span:first-child{font-size:14.5px;font-weight:800;color:var(--ink)}
.bd-sub{font-size:14px;font-weight:800;color:var(--red);font-variant-numeric:tabular-nums;white-space:nowrap}
.bd-subp{font-size:12px;font-weight:700;color:var(--mute);margin-left:2px}
.bd-row{display:flex;align-items:center;gap:8px;padding:3px 0;font-size:14px}
.bd-l{color:var(--mute);font-weight:700;flex:1;min-width:0}
.bd-v{font-weight:700;font-variant-numeric:tabular-nums;white-space:nowrap;flex:none;max-width:130px;overflow:hidden;text-overflow:ellipsis;text-align:right}
.bd-p{flex:none;width:48px;text-align:right;color:var(--mute);font-weight:700;font-size:12.5px;font-variant-numeric:tabular-nums}
.bd-total{margin-top:12px;padding:12px 14px;background:#FBF1EF;border:1.5px solid #E6C9C6;border-radius:12px}
.bd-total .bd-l{color:var(--ink);font-weight:800}
.bd-row.big{font-size:16px;margin-top:4px;padding-top:8px;border-top:1px dashed #E0C4C0}
.bd-row.big .bd-l{font-weight:800}
.bd-v.pos{color:var(--green)}
.bd-v.neg{color:var(--red)}
.scard-h{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:8px}
.scard-h .nm{font-weight:800;font-size:17.5px;flex:1;min-width:0}
.scard-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0;font-size:16px}
.scard-row .k{color:var(--mute);font-weight:700;flex:none}
.scard-row .vv{font-weight:800;font-variant-numeric:tabular-nums;white-space:nowrap;min-width:0;overflow:hidden;text-overflow:ellipsis;text-align:right}
.scard-row .vv.pos{color:var(--green)}
.scard-row .vv.neg{color:var(--red)}
.scard-rates{display:flex;gap:6px;margin-top:9px;border-top:1px solid var(--line);padding-top:10px}
.scard-rates .rt{flex:1;text-align:center}
.scard-rates .rt .k{display:block;font-size:12px;color:var(--mute);font-weight:700;margin-bottom:3px}
.scard-rates .rt .vv{font-size:16px;font-weight:800;font-variant-numeric:tabular-nums}
.scard-rates .rt .vv.warn{color:var(--red)}
.scard-rates .rt .vv.mute{color:var(--mute);font-weight:600}
.rgtag{font-size:13px;font-weight:700;color:var(--gold-d);background:#F6EFD9;border:1px solid #E6D9B0;border-radius:7px;padding:2px 8px;margin-left:2px}
.minibtn{background:var(--soft);color:var(--ink);font-size:16px;font-weight:700;padding:6px 11px;border-radius:8px;box-shadow:none;}
.minibtn:hover{background:#e9e2d4}
.statcards{display:grid;grid-template-columns:1fr;gap:10px;margin-bottom:16px}
.sortbar{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.sortlbl{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:800;color:var(--ink);flex:none;white-space:nowrap}
.sortlbl svg{width:17px;height:17px}
.sortbar select{flex:1;min-width:0}
@media(max-width:760px){.statcards{grid-template-columns:1fr}}
.statc{background:var(--soft);border:1px solid var(--line);border-radius:12px;padding:13px 15px;overflow:hidden;display:flex;justify-content:space-between;align-items:center;gap:12px}
.statc .l{font-size:16px;color:var(--mute);font-weight:700;flex:none}
.statc .v{font-size:23px;font-weight:800;font-variant-numeric:tabular-nums;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0;text-align:right}
.statc .v.gold{color:var(--gold-d)}
.statc .v.green{color:var(--green)}
.toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;position:sticky;top:0;z-index:50;background:var(--paper);margin:0 -20px 14px;padding:12px 20px;box-shadow:0 6px 14px -12px rgba(0,0,0,.35)}
.toolbar .sp{flex:1}
.toolbar select{width:auto;min-width:150px}
.tbtn{display:inline-flex;align-items:center;gap:6px;background:var(--soft);border:1px solid var(--line);border-radius:10px;padding:8px 12px;font-size:14.5px;font-weight:700;color:var(--ink);box-shadow:none;}
.tbtn svg{width:17px;height:17px;flex:none}
.tbtn:hover{background:#e9e2d4}
.msticky{position:sticky;top:0;z-index:50;background:var(--paper);margin:0 -20px 14px;padding:10px 20px 12px;box-shadow:0 6px 14px -12px rgba(0,0,0,.35)}
.mnav{position:relative}.mscroll{display:flex;gap:6px;overflow-x:auto;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:1px}
.mscroll::-webkit-scrollbar{display:none}
.marrow{position:absolute;top:50%;transform:translateY(-50%);width:30px;height:48px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.94);border:1px solid var(--line);border-radius:9px;box-shadow:0 3px 10px -4px rgba(0,0,0,.4);font-size:22px;font-weight:800;color:var(--charcoal);z-index:3;padding:0}
.marrow.left{left:-6px}
.marrow.right{right:-6px}
.mchip{flex:1 0 60px;display:flex;flex-direction:column;align-items:center;gap:5px;padding:9px 2px;border:1.5px solid var(--line);border-radius:11px;background:#fff;box-shadow:none;}
.mchip .mc-y{font-size:10px;color:var(--mute);font-weight:700;line-height:1}
.mchip .mc-m{font-size:15px;font-weight:800;color:var(--ink);white-space:nowrap;line-height:1}
.mchip .mc-st{font-size:10.5px;font-weight:800;padding:2px 6px;border-radius:6px;white-space:nowrap}
.mchip.on{border-color:var(--red);background:#FBEEED;box-shadow:0 0 0 1.5px var(--red) inset}
.mchip.on .mc-m{color:var(--red)}
.mchip:active{transform:translateY(1px)}
.mg-card{margin-bottom:16px;padding:15px 17px}
.mg-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px}
.mg-title{font-size:14px;font-weight:800;color:var(--mute);letter-spacing:.01em}
.mg-legend{display:flex;gap:12px;font-size:12.5px;font-weight:700;color:var(--mute)}
.mg-legend span{display:flex;align-items:center;gap:5px}
.mg-legend .dot{width:9px;height:9px;border-radius:50%;display:inline-block}
.mg-legend .dot.rev{background:#B8231C}
.mg-legend .dot.prof{background:#2C7A4B}
.mg-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-top:10px;padding-top:11px;border-top:1px solid var(--line)}
.mg-stats>div{min-width:0;text-align:center}
.mg-sl{font-size:12.5px;color:var(--mute);font-weight:700;margin-bottom:2px}
.mg-val{font-size:16px;font-weight:800;font-variant-numeric:tabular-nums;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.mg-val.pos{color:var(--green)}
.mg-val.neg{color:var(--red)}
.bigact{display:flex;align-items:center;justify-content:center;gap:8px;color:#fff;padding:16px 12px;font-size:16.5px;font-weight:800;border-radius:13px;box-shadow:0 8px 18px -9px rgba(0,0,0,.45);text-align:center;line-height:1.25}
.bigact svg{width:21px;height:21px;flex:none}
.bigact:hover{filter:brightness(1.08)}
.bigact:active{transform:translateY(1px)}
.lock-note{background:#DDF0E4;border:1px solid #BFE3CC;color:#1f6b40;border-radius:11px;padding:11px 13px;font-size:18px;font-weight:600;margin-bottom:14px}
.warn-note{background:#FDEEEC;border:1px solid #F3CFCB;color:var(--red-d);border-radius:11px;padding:11px 13px;font-size:18px;font-weight:600;margin-bottom:14px}
.linkbtn{background:none;color:var(--red);font-weight:700;font-size:18px;padding:4px 0;box-shadow:none}
.empty{color:var(--mute);text-align:center;padding:26px 8px;font-size:19px}
.cmpgrid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.cmpc{border:1px solid var(--line);border-radius:12px;padding:13px;background:#fff}
.cmpc .l{font-size:16px;color:var(--mute);font-weight:700}
.cmpc .cur{font-size:26px;font-weight:800;margin:3px 0}
.cmpc .prev{font-size:15.5px;color:var(--mute);margin-top:3px}
.delta{font-size:17px;font-weight:800;white-space:nowrap}
.delta.good{color:var(--green)}.delta.bad{color:var(--red)}.delta.flat{color:var(--mute)}
details.cmpdet{margin-top:14px;border:1px solid var(--line);border-radius:12px;overflow:hidden}
details.cmpdet summary{padding:13px 15px;font-weight:800;font-size:19px;cursor:pointer;background:var(--soft);list-style:none}
details.cmpdet summary::-webkit-details-marker{display:none}
details.cmpdet summary:after{content:"▾";float:right;color:var(--mute)}
details.cmpdet[open] summary:after{content:"▴"}
details.cmpdet .inner{padding:4px 12px 12px}
table.cmptable{width:100%;border-collapse:collapse;font-size:18px}
table.cmptable th,table.cmptable td{padding:9px 7px;text-align:right;border-bottom:1px solid var(--line);white-space:nowrap}
table.cmptable th:first-child,table.cmptable td:first-child{text-align:left}
table.cmptable th{font-size:15px;color:var(--mute);font-weight:800}
.rank-list{display:flex;flex-direction:column}.rankrow{display:flex;align-items:center;gap:12px;padding:11px 4px;border-bottom:1px solid var(--line)}
.rankrow:last-child{border-bottom:none}
.rk{flex:0 0 auto;width:26px;height:26px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:18px;background:var(--soft);color:var(--mute)}
.rk.top{background:var(--gold);color:#fff}
.rname{flex:1;font-weight:700;font-size:19px;display:flex;align-items:center;gap:6px;flex-wrap:nowrap;min-width:0}
.rnm-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.rname .rgtag{flex:none}
.rprofit{font-weight:800;color:var(--green);font-variant-numeric:tabular-nums;white-space:nowrap}
.rprofit.neg{color:var(--red)}
@media(max-width:760px){.rankrow{gap:8px;padding:10px 2px}.rname{font-size:14.5px;gap:5px}.rprofit{font-size:14px}.rmargin{width:42px;font-size:12px}.rk{width:22px;height:22px;font-size:14px}.rgtag{font-size:11px;padding:1px 5px}}
.rmargin{flex:0 0 auto;width:54px;text-align:right;color:var(--ink);font-size:15px;font-weight:700;font-variant-numeric:tabular-nums}
.foot{text-align:center;color:var(--mute);font-size:16px;padding:24px}
.toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%) translateY(20px);background:var(--charcoal);color:#fff;padding:13px 20px;border-radius:12px;font-size:19px;font-weight:700;box-shadow:0 14px 34px -14px rgba(0,0,0,.55);opacity:0;transition:opacity .2s,transform .2s;z-index:9999;pointer-events:none;max-width:88vw;text-align:center}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.modal-bg{position:fixed;inset:0;background:rgba(20,18,16,.5);display:flex;align-items:center;justify-content:center;z-index:9998;padding:20px}
.modal{background:#fff;border-radius:16px;padding:22px;max-width:370px;width:100%;box-shadow:0 24px 60px -24px rgba(0,0,0,.55)}
.modal p{font-size:20.5px;font-weight:600;line-height:1.55;margin-bottom:18px}
.modal .btns{margin:0}