:root{color:#161827;font-synthesis:none;text-rendering:optimizelegibility;background:#f7f8fc;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5}*{box-sizing:border-box}body{background:#f7f8fc;min-width:320px;margin:0}button{color:inherit;cursor:pointer;font:inherit;border:0}.app-shell{grid-template-columns:176px minmax(0,1fr);min-height:100dvh;display:grid}.sidebar{background:#fbfbfe;border-right:1px solid #e8eaf2;align-content:start;height:100dvh;padding:24px 14px;display:grid;position:sticky;top:0}.brand{align-items:center;gap:8px;margin:0 6px 48px;display:flex}.brand-symbol{width:24px;height:24px;position:relative}.brand-symbol:before,.brand-symbol:after{content:"";background:#5c22f0;border-radius:999px;position:absolute;inset:9px 1px}.brand-symbol:after{transform:rotate(90deg)}.brand strong{color:#202136;font-size:28px;line-height:.9;display:block}.brand span{color:#626a7d;font-size:10px;font-weight:700;display:block}.side-nav{gap:10px;display:grid}.side-nav a{color:#777d8e;border-radius:8px;align-items:center;gap:10px;min-height:42px;padding:0 10px;font-size:14px;font-weight:800;text-decoration:none;display:flex}.side-nav a.active{color:#fff;background:linear-gradient(135deg,#6c30f7,#3f1fdf);box-shadow:0 8px 18px #5825e538}.nav-icon,.stat-icon,.reason-icon,.calendar-icon,.chevron{flex:none;display:inline-block}.nav-icon{border:2px solid;border-radius:6px;width:20px;height:20px}.chart-icon{border-radius:50%}.tag-icon{transform:rotate(-45deg)}.sidebar-note{color:#858b9b;border-top:1px solid #e7e9f2;align-self:end;margin-top:calc(100dvh - 375px);padding:18px 6px 0;font-size:11px}.sidebar-note p{margin:0 0 18px}.dashboard{min-width:0;padding:28px 32px 32px}.topbar{justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:22px;display:flex}h1,h2,p{margin-top:0}h1{color:#151727;margin-bottom:6px;font-size:28px;line-height:1.15}h2{color:#1b1d2d;margin-bottom:0;font-size:17px;line-height:1.2}.topbar p,.card-header p{color:#6e7484;margin:6px 0 0;font-size:13px}.toolbar{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}.date-button,.store-button{color:#282b3d;background:#fff;border:1px solid #e4e7f0;border-radius:8px;align-items:center;gap:10px;min-height:42px;padding:6px 12px;font-size:13px;font-weight:800;display:flex;box-shadow:0 4px 14px #1415260a}.calendar-icon{border:2px solid #767d90;border-radius:4px;width:16px;height:16px}.store-button{justify-content:flex-start;min-width:230px}.store-thumb{background:linear-gradient(90deg,#372ac4 0 34%,#45b7ff 34% 67%,#8bd644 67%),#eee;border-radius:6px;width:42px;height:32px;position:relative;overflow:hidden}.store-thumb:after{content:"";background:#ffffffbf;border-radius:2px;height:12px;position:absolute;bottom:4px;left:4px;right:4px}.store-button span:nth-child(2){text-align:left;gap:1px;display:grid}.store-button small{color:#7c8292;font-size:10px;font-weight:700}.chevron{border-bottom:2px solid #7d8393;border-right:2px solid #7d8393;width:8px;height:8px;margin-left:auto;transform:rotate(45deg)translateY(-2px)}.content-grid{grid-template-columns:minmax(650px,1fr) minmax(360px,430px);gap:18px;display:grid}.right-column{align-content:start;gap:18px;display:grid}.card{background:#fff;border:1px solid #eceef5;border-radius:8px;box-shadow:0 12px 30px #1e1f320a}.comparison-card{padding:24px 20px}.promotion-card,.summary-card{padding:22px 18px}.card-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.card-header>div:first-child{min-width:0}.card-header h2{align-items:center;gap:7px;display:inline-flex}.info-dot{color:#8991a3;border:1px solid #c5cad8;border-radius:50%;place-items:center;width:15px;height:15px;font-size:10px;font-weight:900;display:inline-grid}.mode-toggle,.all-toggle{color:#767d8d;white-space:nowrap;align-items:center;gap:12px;font-size:13px;font-weight:800;display:flex}.mode-toggle strong{color:#4c22e8}.switch{background:#f3f4f8;border:1px solid #dddff0;border-radius:999px;width:70px;height:34px;transition:background .16s;position:relative}.switch span{background:#fff;border-radius:50%;width:26px;height:26px;transition:transform .16s;position:absolute;top:3px;left:4px;box-shadow:0 4px 12px #0f10202e}.switch.on{background:linear-gradient(90deg,#4a22e7,#7d4cff);border-color:#4c22e8}.switch.on span{transform:translate(34px)}.switch.small{width:50px;height:26px}.switch.small span{width:20px;height:20px;top:2px;left:3px}.switch.small.on span{transform:translate(23px)}.revenue-compare{grid-template-columns:1fr 1fr;margin:6px 0 26px;padding-bottom:46px;display:grid;position:relative}.revenue-box{text-align:center;background:#f7f7fa;border:1px solid #e4e6ef;border-radius:7px;place-items:center;min-height:86px;display:grid}.revenue-box span{color:#7a8090;font-size:13px;font-weight:900}.revenue-box strong{color:#191b2b;font-size:24px;line-height:1.1}.revenue-box.on{background:linear-gradient(135deg,#6f30f7 0%,#4b1ddd 62%,#3b16c7 100%);border-color:#0000}.revenue-box.on span,.revenue-box.on strong{color:#fff}.versus{z-index:2;color:#5e6372;background:#fff;border-radius:50%;place-items:center;width:46px;height:46px;font-weight:900;display:grid;position:absolute;top:33px;left:50%;transform:translate(-50%);box-shadow:0 4px 16px #211c461f}.revenue-delta{color:#4d22e8;background:#fbfaff;border:1px solid #eeeef7;border-radius:4px;justify-content:center;align-items:center;min-width:320px;min-height:44px;font-size:18px;font-weight:900;display:inline-flex;position:absolute;bottom:0;left:50%;transform:translate(-50%)}.revenue-delta small{color:#17995c;margin-left:10px;font-size:13px}.chart-area{margin-top:8px;padding-top:28px;position:relative}.chart-label{color:#777e90;font-size:12px;font-weight:800;position:absolute;top:2px;left:0}.chart-legend{color:#73798a;gap:22px;font-size:12px;font-weight:800;display:flex;position:absolute;top:0;left:50%;transform:translate(-50%)}.chart-legend span{align-items:center;gap:7px;display:flex}.chart-legend i{border-radius:999px;width:18px;height:3px}.chart-legend .off{background:#7d8291}.chart-legend .on{background:#4d22e8}.chart-area svg{width:100%;height:300px;display:block;overflow:visible}.grid-line{stroke:#edf0f5;stroke-width:1px}.axis-label,.day-label{fill:#767d8e;font-size:12px;font-weight:700}.chart-fill{fill:url(#promotionFill)}.line{fill:none;stroke-linecap:round;stroke-linejoin:round;stroke-width:4px}.line.off{stroke:#7a7f91}.line.on{stroke:#4d22e8}.dot{fill:#fff;stroke-width:4px}.dot.off{stroke:#7a7f91}.dot.on{stroke:#4d22e8}.marker-line{stroke:#cbd0df;stroke-width:1px}.tooltip{z-index:3;color:#282b3d;background:#fffffff5;border:1px solid #e5e7f0;border-radius:7px;width:150px;padding:12px;font-size:11px;position:absolute;top:82px;transform:translate(-50%);box-shadow:0 12px 26px #1b1d321a}.tooltip strong{margin-bottom:8px;font-size:12px;display:block}.tooltip strong span{color:#777e90;font-weight:800}.tooltip p{justify-content:space-between;margin:3px 0;display:flex}.tooltip em{color:#09935a;font-style:normal;font-weight:900}.stat-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-top:18px;display:grid}.stat-tile{background:#fbfbfe;border:1px solid #eceef5;border-radius:7px;align-items:center;gap:12px;min-height:64px;padding:12px 16px;display:flex}.stat-tile span:not(.stat-icon){color:#848a9a;font-size:12px;font-weight:800;display:block}.stat-tile strong{color:#4d22e8;margin-top:2px;font-size:16px;line-height:1.15;display:block}.stat-icon,.reason-icon{color:#5b2cf0;width:30px;height:30px;position:relative}.stat-icon:before,.stat-icon:after,.reason-icon:before,.reason-icon:after{content:"";position:absolute}.bar:before,.trend:before{border-left:5px solid;border-right:5px solid;inset:7px 5px 5px}.bar:after{background:currentColor;width:5px;height:22px;bottom:5px;right:4px}.bag:before{background:currentColor;border-radius:4px;inset:9px 6px 5px}.bag:after{border:3px solid;border-bottom:0;border-radius:8px 8px 0 0;width:10px;height:10px;top:3px;left:10px}.trend:after{border-top:4px solid;border-right:4px solid;width:20px;height:16px;bottom:5px;right:2px;transform:skewY(-28deg)}.users:before{background:currentColor;border-radius:50%;width:9px;height:9px;top:5px;left:11px}.users:after{background:currentColor;border-radius:12px 12px 3px 3px;height:13px;bottom:5px;left:5px;right:5px}.reason-panel{border:1px solid #eff1f7;border-radius:7px;margin-top:24px;padding:20px 18px}.reason-panel h2{margin-bottom:18px;font-size:15px}.equation{grid-template-columns:1fr auto 1fr auto 1fr auto 1fr auto 1fr;align-items:center;gap:10px;display:grid}.reason-item{text-align:center;justify-items:center;gap:7px;min-width:0;display:grid}.reason-icon{background:#f4f0ff;border-radius:50%;place-items:center;display:grid}.reason-icon:before{background:currentColor;border-radius:3px;inset:8px}.reason-item.discount .reason-icon,.reason-item.negative .reason-icon{color:#e94372;background:#ffeaf1}.reason-item p{color:#767d8e;margin:0;font-size:12px;font-weight:800}.reason-item strong{color:#4d22e8;white-space:nowrap;font-size:13px}.reason-item.negative strong{color:#e94372}.operator{color:#5f6574;font-size:22px;font-weight:900}.promotion-list{gap:9px;display:grid}.promotion-row{background:#fff;border:1px solid #eceef5;border-radius:7px;grid-template-columns:62px minmax(0,1fr) auto 112px;align-items:center;gap:12px;min-height:74px;padding:10px;display:grid}.product-image{background:#f1f3f8;border-radius:7px;justify-content:center;align-items:center;gap:4px;height:50px;display:flex;position:relative;overflow:hidden}.product-image span{background:var(--product-color,#4d22e8);border-radius:5px 5px 3px 3px;width:13px;height:36px;display:block;box-shadow:inset 0 8px #ffffff61}.product-image span:nth-child(2){filter:brightness(1.2);height:42px}.product-image span:nth-child(3){filter:brightness(.84);height:31px}.drink{--product-color:#ca2a2f;background:#f8e9dc}.rice{--product-color:#111827;background:#fff0dd}.rice span{border-radius:6px;width:18px;height:36px}.sandwich{--product-color:#f5a524;background:#fff4d8}.sandwich span{width:16px;height:38px}.coffee{--product-color:#493229;background:#efe6db}.snack{--product-color:#e52035;background:#fff3c8}.snack span{width:17px;height:31px;transform:skew(-8deg)}.promotion-copy{min-width:0}.promotion-copy strong{color:#2c2f40;text-overflow:ellipsis;white-space:nowrap;font-size:14px;line-height:1.2;display:block;overflow:hidden}.promotion-copy span,.impact span{color:#818797;margin-top:5px;font-size:11px;font-weight:800;display:block}.impact{border-left:1px solid #edf0f6;justify-items:end;min-width:0;padding-left:10px;display:grid}.impact strong{color:#139962;white-space:nowrap;font-size:13px;line-height:1.15}.impact.down strong{color:#e94372}.impact i{border-bottom:6px solid #139962;border-left:4px solid #0000;border-right:4px solid #0000;width:0;height:0;margin-top:4px}.impact.down i{border-top:6px solid #e94372;border-bottom:0}.notice{color:#6b58d7;background:#f4f1ff;border-radius:4px;align-items:center;gap:8px;min-height:32px;margin-top:14px;padding:8px 10px;font-size:11px;font-weight:800;display:flex}.notice span{background:#e6defe;border-radius:50%;place-items:center;width:15px;height:15px;font-size:10px;display:grid}.notice.strong{color:#455066}.notice.strong b{color:#139962}.summary-card h2{margin-bottom:20px}.summary-layout{grid-template-columns:170px 1fr;align-items:center;gap:14px;display:grid}.donut-wrap{place-items:center;width:168px;height:168px;display:grid;position:relative}.donut{transform:rotate(-90deg)}.donut-track,.donut-segment{fill:none;stroke-width:18px}.donut-track{stroke:#edeaf7}.donut-segment{stroke-linecap:round}.donut-center{text-align:center;justify-items:center;display:grid;position:absolute}.donut-center span{color:#798092;font-size:12px;font-weight:900}.donut-center strong{color:#202335;font-size:16px}.donut-center small{color:#15915d;font-size:11px;font-weight:900}.summary-list{gap:13px;display:grid}.summary-row{color:#555c70;justify-content:space-between;align-items:center;gap:12px;font-size:12px;font-weight:800;display:flex}.summary-row span{white-space:nowrap;align-items:center;gap:8px;min-width:0;display:flex}.summary-row i{border-radius:50%;width:8px;height:8px}.summary-row strong{color:#161827;white-space:nowrap;flex:none;font-size:12px}.summary-row strong.positive{color:#202335}.summary-row strong.negative{color:#e94372}@media (width<=1220px){.content-grid{grid-template-columns:1fr}.right-column{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}}@media (width<=920px){.app-shell{grid-template-columns:1fr}.sidebar{height:auto;padding:16px;position:static}.brand{margin-bottom:18px}.side-nav{grid-template-columns:repeat(2,minmax(0,1fr))}.sidebar-note{display:none}.dashboard{padding:20px}.topbar{display:grid}.toolbar{justify-content:stretch}.date-button,.store-button{flex:1}.right-column,.stat-grid,.equation{grid-template-columns:1fr}.operator{justify-self:center}}@media (width<=680px){.dashboard{padding:14px}.comparison-card,.promotion-card,.summary-card{padding:16px}.card-header,.all-toggle{justify-items:start;display:grid}.mode-toggle{flex-wrap:wrap}.revenue-compare{grid-template-columns:1fr;gap:10px;padding-bottom:0}.versus{justify-self:center;margin:-3px 0;position:static;transform:none}.revenue-delta{width:100%;min-width:0;font-size:16px;position:static;transform:none}.chart-legend{margin-bottom:8px;position:static;transform:none}.tooltip{display:none}.promotion-row{grid-template-columns:58px minmax(0,1fr) auto}.impact{border-top:1px solid #edf0f6;border-left:0;grid-column:2/-1;justify-items:start;padding:8px 0 0}.summary-layout{grid-template-columns:1fr;justify-items:center}}
