:root{
  --bg:#f3f6fb;--bg2:#eef3f9;--panel:rgba(255,255,255,.92);--panel-solid:#fff;
  --text:#101828;--muted:#667085;--subtle:#98a2b3;--blue:#0a84ff;--blue2:#4aa3ff;
  --green:#22c55e;--red:#ef4444;--orange:#f59e0b;--line:#e6eaf0;
  --shadow:0 16px 40px rgba(16,24,40,.08);--shadow-sm:0 6px 20px rgba(16,24,40,.06);
  --r:24px;--r-sm:16px;--sidebar:270px;--safe-bottom:env(safe-area-inset-bottom,0px)
}
*{box-sizing:border-box}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{margin:0;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,"SF Pro Display","Segoe UI",Prompt,Kanit,sans-serif;background:radial-gradient(circle at 80% 0,rgba(10,132,255,.06),transparent 28%),linear-gradient(180deg,#f8fafc 0%,var(--bg) 42%,var(--bg2) 100%);color:var(--text);overflow-x:hidden}button,input,select,textarea{font:inherit}a{text-decoration:none;color:inherit}img{max-width:100%}

/* App shell */
.app-shell{min-height:100vh;display:grid;grid-template-columns:var(--sidebar) minmax(0,1fr)}
.sidebar{position:sticky;top:0;height:100vh;padding:18px 14px 16px;background:rgba(255,255,255,.82);backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);border-right:1px solid rgba(226,232,240,.9);display:flex;flex-direction:column;z-index:50}
.brand{display:flex;gap:12px;align-items:center;padding:5px 8px 18px}.brand-mark{width:44px;height:44px;flex:0 0 44px;border-radius:14px;background:linear-gradient(145deg,#0a84ff,#5eb0ff);color:#fff;display:grid;place-items:center;font-weight:800;letter-spacing:.2px;box-shadow:0 12px 26px rgba(10,132,255,.28)}.brand b{font-size:15px}.brand small,.user-mini small{display:block;color:var(--muted);font-size:11px;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar nav{overflow:auto;display:grid;gap:3px;padding:2px 3px 12px;scrollbar-width:thin}.sidebar nav a{min-height:43px;padding:10px 12px;border-radius:14px;color:#475467;display:flex;gap:11px;align-items:center;font-size:13px;font-weight:600;transition:.18s ease}.sidebar nav a>span{width:18px;text-align:center;color:#667085}.sidebar nav a:hover,.sidebar nav a.active{background:#fff;color:var(--blue);box-shadow:var(--shadow-sm)}.sidebar nav a.active>span{color:var(--blue)}
.sidebar-foot{margin-top:auto;padding:14px 8px 0;border-top:1px solid var(--line)}.user-mini{min-width:0}.logout{display:inline-flex;margin-top:10px;color:var(--red);font-size:12px;font-weight:700}
.main{padding:26px clamp(18px,2.4vw,38px) 42px;min-width:0;width:100%}.topbar{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:22px}.topbar>div:nth-child(2){flex:1;min-width:0}.topbar h1{margin:0;font-size:clamp(25px,2.4vw,34px);line-height:1.15;letter-spacing:-.7px}.topbar p{margin:5px 0 0;color:var(--muted);font-size:14px}.date-pill,.badge{padding:9px 13px;border-radius:999px;background:rgba(255,255,255,.95);box-shadow:var(--shadow-sm);font-size:12px;white-space:nowrap}.mobile-menu{display:none;border:0;background:#fff;width:42px;height:42px;border-radius:14px;box-shadow:var(--shadow-sm);font-size:19px;color:#344054}.sidebar-backdrop{display:none}.mobile-bottom-nav{display:none}

/* Layout & cards */
.grid{display:grid;gap:18px}.kpis{grid-template-columns:repeat(4,minmax(0,1fr))}.split{grid-template-columns:minmax(0,1.35fr) minmax(300px,.9fr)}.card{background:var(--panel);border:1px solid rgba(255,255,255,.88);border-radius:var(--r);box-shadow:var(--shadow);padding:20px;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);min-width:0}.kpi{position:relative;overflow:hidden}.kpi:after{content:"";position:absolute;right:-34px;top:-38px;width:105px;height:105px;border-radius:50%;background:currentColor;opacity:.045}.kpi .label{color:var(--muted);font-size:12px;font-weight:650}.kpi .value{font-size:clamp(24px,2.2vw,31px);font-weight:800;margin-top:8px;letter-spacing:-.6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.kpi.blue{border-top:4px solid var(--blue);color:var(--blue)}.kpi.green{border-top:4px solid var(--green);color:var(--green)}.kpi.red{border-top:4px solid var(--red);color:var(--red)}.kpi.orange{border-top:4px solid var(--orange);color:var(--orange)}.kpi .label,.kpi .value{color:var(--text)}
.section-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px}.section-head h2{margin:0;font-size:18px;letter-spacing:-.2px}.chart-box{position:relative;min-height:300px;width:100%}.empty{padding:28px 10px;text-align:center;color:var(--muted)}

/* Controls */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:42px;padding:10px 15px;border-radius:14px;border:1px solid rgba(226,232,240,.9);background:#fff;color:#344054;cursor:pointer;box-shadow:0 4px 14px rgba(16,24,40,.05);font-weight:700;font-size:13px;transition:.18s ease}.btn:hover{transform:translateY(-1px);box-shadow:0 8px 20px rgba(16,24,40,.08)}.btn:active{transform:scale(.985)}.btn.primary{background:linear-gradient(135deg,var(--blue),#238eff);border-color:transparent;color:#fff;box-shadow:0 9px 22px rgba(10,132,255,.22)}.btn.danger{background:#fff1f2;color:#dc2626;border-color:#ffe4e6}.btn.success{background:#ecfdf3;color:#15803d;border-color:#d1fae5}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.field{display:grid;gap:7px;min-width:0}.field.full{grid-column:1/-1}.field label{font-size:12px;color:#667085;font-weight:650}.field input,.field select,.field textarea{width:100%;min-height:46px;padding:12px 13px;border-radius:14px;border:1px solid #dfe4ea;background:rgba(255,255,255,.96);outline:none;color:var(--text);transition:.18s ease}.field textarea{min-height:110px;resize:vertical}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--blue);box-shadow:0 0 0 4px rgba(10,132,255,.10)}
table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:13px 10px;border-bottom:1px solid #edf0f3;font-size:13px;vertical-align:middle}th{color:#667085;font-weight:700;background:rgba(248,250,252,.65);position:sticky;top:0}td.num{text-align:right;font-variant-numeric:tabular-nums}.table-wrap{overflow:auto;border-radius:14px;-webkit-overflow-scrolling:touch}.table-wrap table{min-width:680px}
.alert{padding:13px 15px;border-radius:15px;margin-bottom:14px;font-size:13px;line-height:1.55}.alert.success{background:#ecfdf3;color:#166534;border:1px solid #d1fae5}.alert.error{background:#fff1f2;color:#be123c;border:1px solid #ffe4e6}.progress{height:10px;border-radius:999px;background:#e5e7eb;overflow:hidden}.progress span{display:block;height:100%;background:linear-gradient(90deg,var(--blue),#60a5fa)}.tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.tabs a{padding:9px 13px;border-radius:12px;background:#fff;font-size:13px;font-weight:650}.tabs a.active{background:var(--blue);color:#fff}

/* Auth */
.auth-page{min-height:100dvh;display:grid;place-items:center;padding:clamp(18px,4vw,40px);background:radial-gradient(circle at 22% 15%,rgba(10,132,255,.12),transparent 24%),radial-gradient(circle at 80% 85%,rgba(34,197,94,.08),transparent 22%),linear-gradient(180deg,#f8fafc,#eef3f9)}.auth-page:before{content:"MB";position:fixed;left:clamp(24px,6vw,90px);top:50%;transform:translateY(-50%);font-size:clamp(100px,18vw,260px);font-weight:900;color:rgba(10,132,255,.035);letter-spacing:-12px;pointer-events:none}.auth-card{width:min(460px,100%);padding:clamp(24px,4vw,36px);position:relative}.auth-card h1{font-size:clamp(31px,5vw,42px);margin:0 0 8px;letter-spacing:-1px}.auth-card>p{color:var(--muted);margin:0 0 22px}.auth-card .field{margin-bottom:13px}.auth-card>p:last-child{margin:20px 0 0;color:#475467;text-align:center;font-size:13px}.auth-card a:not(.btn-line){color:var(--blue);font-weight:700}.auth-divider{display:flex;align-items:center;gap:12px;margin:18px 0;color:#98a2b3}.auth-divider span{height:1px;background:#e5e7eb;flex:1}.btn-line{display:inline-flex;align-items:center;justify-content:center;width:100%;min-height:50px;padding:12px 20px;border:0;border-radius:15px;background:#06c755;color:#fff!important;font-weight:800;text-decoration:none;box-shadow:0 10px 24px rgba(6,199,85,.20);transition:.18s ease}.btn-line:hover{filter:brightness(.97);transform:translateY(-1px)}.btn-line:before{content:"LINE";font-size:10px;padding:5px 6px;border-radius:6px;background:#fff;color:#06c755;margin-right:10px;font-weight:900}

/* Landing */
.landing{max-width:1220px;margin:auto;padding:22px clamp(18px,4vw,38px) 60px}.landing>.topbar{position:sticky;top:12px;z-index:10;padding:10px 12px;border-radius:20px;background:rgba(255,255,255,.78);backdrop-filter:blur(22px);box-shadow:var(--shadow-sm)}.hero{padding:clamp(58px,9vw,108px) 0;display:grid;grid-template-columns:minmax(0,1.15fr) minmax(380px,.85fr);gap:42px;align-items:center}.hero h1{font-size:clamp(46px,6vw,76px);line-height:1.02;margin:16px 0 20px;letter-spacing:-2.5px}.hero p{font-size:clamp(17px,2vw,21px);line-height:1.65;color:#667085;max-width:720px}.feature-grid{grid-template-columns:repeat(3,1fr)}.feature-grid .card h3{margin:0 0 8px}.feature-grid .card p{margin:0;color:var(--muted);line-height:1.55;font-size:14px}

/* LINE */
.line-status{display:flex;gap:14px;align-items:center;padding:16px;border-radius:18px;background:#f8fafc;border:1px solid rgba(148,163,184,.18)}.line-avatar{width:52px;height:52px;flex:0 0 52px;border-radius:50%;object-fit:cover;background:#e5e7eb}.status-dot{width:10px;height:10px;border-radius:50%;display:inline-block;margin-right:6px}.status-dot.on{background:#30d158}.status-dot.off{background:#8e8e93}

@media(max-width:1180px){:root{--sidebar:238px}.kpis{grid-template-columns:repeat(2,minmax(0,1fr))}.split{grid-template-columns:1fr}.hero{grid-template-columns:1fr 390px}}

@media(max-width:820px){
  body{background:#f4f7fb}.app-shell{display:block}.sidebar{position:fixed;left:0;top:0;bottom:0;width:min(86vw,320px);height:100dvh;transform:translateX(-105%);transition:transform .24s cubic-bezier(.4,0,.2,1);box-shadow:20px 0 50px rgba(16,24,40,.14);padding-top:max(18px,env(safe-area-inset-top));z-index:100}.sidebar.open{transform:none}.sidebar-backdrop{display:block;position:fixed;inset:0;background:rgba(15,23,42,.32);backdrop-filter:blur(2px);opacity:0;visibility:hidden;transition:.2s;z-index:90}.sidebar-backdrop.show{opacity:1;visibility:visible}.main{padding:max(14px,env(safe-area-inset-top)) 14px calc(92px + var(--safe-bottom))}.topbar{position:sticky;top:0;z-index:30;margin:-14px -14px 16px;padding:14px;background:rgba(244,247,251,.88);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(226,232,240,.65)}.mobile-menu{display:inline-grid;place-items:center;flex:0 0 42px}.topbar h1{font-size:23px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar p{font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.date-pill{display:none}.card{border-radius:20px;padding:17px}.section-head h2{font-size:16px}.chart-box{min-height:245px}.form-grid{grid-template-columns:1fr}.field.full{grid-column:auto}.feature-grid,.hero{grid-template-columns:1fr}.hero{padding:48px 0 34px;gap:24px}.hero h1{font-size:44px;letter-spacing:-1.5px}.hero .card{display:none}.landing>.topbar{top:8px}.landing>.topbar .brand small{display:none}.landing>.topbar .btn{padding:9px 11px;min-height:39px}.mobile-bottom-nav{position:fixed;left:10px;right:10px;bottom:calc(8px + var(--safe-bottom));height:66px;padding:7px 8px;display:grid;grid-template-columns:repeat(5,1fr);gap:3px;background:rgba(255,255,255,.94);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.9);box-shadow:0 12px 35px rgba(16,24,40,.18);border-radius:22px;z-index:80}.mobile-bottom-nav a{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;border-radius:15px;color:#667085;font-size:10px;font-weight:650;min-width:0}.mobile-bottom-nav a span{font-size:18px;line-height:1}.mobile-bottom-nav a.active{background:#edf6ff;color:var(--blue)}
}

@media(max-width:560px){
  .main{padding-left:11px;padding-right:11px}.topbar{margin-left:-11px;margin-right:-11px;padding-left:11px;padding-right:11px}.kpis{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.kpi{padding:15px 13px}.kpi .value{font-size:21px}.kpi .label{font-size:11px}.grid{gap:12px}.card{padding:15px}.split{gap:12px}.auth-page{padding:16px;align-items:center}.auth-page:before{display:none}.auth-card{padding:24px 20px;border-radius:24px}.auth-card h1{font-size:34px}.hero h1{font-size:39px}.feature-grid{gap:12px}.landing{padding-left:14px;padding-right:14px}.landing>.topbar{padding:8px}.brand-mark{width:40px;height:40px;flex-basis:40px}.table-wrap{margin:0 -15px;padding:0 15px}.tabs{overflow-x:auto;flex-wrap:nowrap;padding-bottom:4px}.tabs a{white-space:nowrap}.line-status{align-items:flex-start}.section-head{align-items:flex-start;flex-direction:column}.section-head .btn{width:100%}
}

@media(max-width:390px){.kpis{grid-template-columns:1fr}.mobile-bottom-nav{left:6px;right:6px}.mobile-bottom-nav a{font-size:9px}.auth-card{padding:22px 17px}}

@media(min-width:1600px){.main{max-width:1650px;margin:0 auto;width:100%}.card{padding:24px}.chart-box{min-height:360px}}

@media(prefers-reduced-motion:reduce){*{scroll-behavior:auto!important;transition:none!important;animation:none!important}}

/* --------------------------------------------------------------------------
   Responsive navigation stability patch – 2026-07
   -------------------------------------------------------------------------- */
.sidebar-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.sidebar-head .brand{flex:1;min-width:0}.sidebar-close{display:none;width:42px;height:42px;border:0;border-radius:14px;background:#f2f4f7;color:#344054;font-size:30px;line-height:1;cursor:pointer}.sidebar-nav a strong{font:inherit}.topbar-title{flex:1;min-width:0}.mobile-menu{cursor:pointer;align-content:center;justify-items:center;gap:4px;padding:0}.mobile-menu span{display:block;width:19px;height:2px;border-radius:9px;background:#344054;transition:transform .2s ease,opacity .2s ease}.sidebar-backdrop{border:0;padding:0;margin:0;pointer-events:none}.mobile-bottom-nav a b{font:inherit}.mobile-add span{width:37px!important;height:37px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(145deg,#0a84ff,#58aaff);color:#fff!important;box-shadow:0 7px 18px rgba(10,132,255,.3);font-size:25px!important;margin-top:-18px}.mobile-add b{margin-top:1px}

@media(max-width:900px){
  :root{--mobile-nav-height:76px}
  .app-shell{display:block;min-height:100dvh}
  .sidebar{position:fixed!important;inset:0 auto 0 0!important;width:min(88vw,340px)!important;height:100dvh!important;transform:translate3d(-104%,0,0)!important;visibility:hidden;transition:transform .24s cubic-bezier(.22,1,.36,1),visibility 0s linear .24s!important;z-index:1000!important;background:rgba(255,255,255,.97)!important;border-right:1px solid rgba(226,232,240,.9);box-shadow:24px 0 70px rgba(15,23,42,.18);padding:max(14px,env(safe-area-inset-top)) 12px max(14px,env(safe-area-inset-bottom));overflow:hidden}
  .drawer-open .sidebar{transform:translate3d(0,0,0)!important;visibility:visible;transition:transform .24s cubic-bezier(.22,1,.36,1),visibility 0s!important}
  .sidebar-head{position:relative;z-index:2;padding-right:2px}.sidebar-close{display:grid;place-items:center;flex:0 0 42px}
  .sidebar-nav{overscroll-behavior:contain;padding-bottom:18px!important}.sidebar nav a{min-height:48px;border-radius:15px;font-size:14px;padding:11px 13px}.sidebar nav a>span{font-size:17px;width:22px}.sidebar nav a.active{background:linear-gradient(135deg,#edf6ff,#f6fbff);box-shadow:inset 0 0 0 1px rgba(10,132,255,.08),0 7px 18px rgba(16,24,40,.05)}
  .sidebar-backdrop{display:block!important;position:fixed!important;inset:0!important;z-index:990!important;background:rgba(15,23,42,.38)!important;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);opacity:0!important;visibility:hidden!important;pointer-events:none!important;transition:opacity .2s ease,visibility 0s linear .2s!important}
  .drawer-open .sidebar-backdrop{opacity:1!important;visibility:visible!important;pointer-events:auto!important;transition:opacity .2s ease,visibility 0s!important}
  .drawer-open{overflow:hidden!important;touch-action:none}.drawer-open .sidebar{touch-action:auto}
  .main{min-height:100dvh;padding:max(12px,env(safe-area-inset-top)) 12px calc(var(--mobile-nav-height) + 24px + env(safe-area-inset-bottom))!important}
  .topbar{position:sticky!important;top:0!important;z-index:100!important;margin:-12px -12px 16px!important;padding:max(12px,env(safe-area-inset-top)) 12px 12px!important;background:rgba(244,247,251,.94)!important;border-bottom:1px solid rgba(226,232,240,.7);box-shadow:0 5px 18px rgba(16,24,40,.04)}
  .mobile-menu{display:grid!important;position:relative;z-index:3;flex:0 0 44px;width:44px;height:44px;border-radius:15px}.topbar h1{font-size:22px!important}.topbar p{font-size:11px!important}.date-pill{display:none!important}
  .mobile-bottom-nav{display:grid!important;position:fixed!important;z-index:900!important;left:10px!important;right:10px!important;bottom:calc(8px + env(safe-area-inset-bottom))!important;height:70px!important;grid-template-columns:repeat(5,minmax(0,1fr))!important;align-items:center;padding:7px 7px!important;border-radius:23px!important;background:rgba(255,255,255,.96)!important;border:1px solid rgba(255,255,255,.95)!important;box-shadow:0 14px 44px rgba(16,24,40,.2)!important;backdrop-filter:blur(26px);-webkit-backdrop-filter:blur(26px)}
  .mobile-bottom-nav a{position:relative;z-index:1;min-height:54px;border-radius:16px;display:flex!important;flex-direction:column;align-items:center;justify-content:center;gap:2px;color:#667085;font-size:10px;font-weight:700;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.mobile-bottom-nav a span{font-size:18px}.mobile-bottom-nav a.active:not(.mobile-add){background:#edf6ff;color:#087eea}.mobile-bottom-nav a:active{transform:scale(.96)}
  .card{border-radius:21px!important;box-shadow:0 11px 32px rgba(16,24,40,.07)!important}.kpis{grid-template-columns:repeat(2,minmax(0,1fr))!important}.split{grid-template-columns:1fr!important}.chart-box{min-height:235px!important}.btn{min-height:46px}.field input,.field select,.field textarea{font-size:16px}
}

@media(max-width:520px){
  .main{padding-left:10px!important;padding-right:10px!important}.topbar{margin-left:-10px!important;margin-right:-10px!important;padding-left:10px!important;padding-right:10px!important}.topbar{gap:10px}.topbar h1{font-size:20px!important}.topbar p{max-width:220px}.card{padding:15px!important}.grid{gap:11px!important}.kpis{gap:10px!important}.kpi{min-height:116px;display:flex;flex-direction:column;justify-content:center}.kpi .value{font-size:22px!important}.section-head{gap:9px}.section-head h2{font-size:16px}.table-wrap{width:calc(100% + 30px);margin-left:-15px;padding:0 15px;overflow-x:auto;overscroll-behavior-inline:contain}.mobile-bottom-nav{left:6px!important;right:6px!important}.mobile-bottom-nav a{font-size:9px}.mobile-add span{width:35px!important;height:35px}
}

@media(max-width:370px){.kpis{grid-template-columns:1fr!important}.topbar p{display:none}.mobile-bottom-nav a b{font-size:8px}}

/* ========================================================================== 
   Mobile data tables → native card list (LINE Mini App / small screens)
   No horizontal scrolling. Desktop tables remain unchanged.
   ========================================================================== */
@media (max-width: 720px) {
  .table-wrap{
    width:100%!important;
    margin:0!important;
    padding:0!important;
    overflow:visible!important;
  }

  table.mobile-card-table{
    display:block;
    width:100%;
    min-width:0!important;
    border:0;
    background:transparent;
  }

  table.mobile-card-table thead{
    position:absolute!important;
    width:1px!important;
    height:1px!important;
    padding:0!important;
    margin:-1px!important;
    overflow:hidden!important;
    clip:rect(0,0,0,0)!important;
    white-space:nowrap!important;
    border:0!important;
  }

  table.mobile-card-table tbody{
    display:grid;
    width:100%;
    gap:12px;
  }

  table.mobile-card-table tr{
    display:grid;
    width:100%;
    min-width:0;
    grid-template-columns:minmax(0,1fr);
    gap:0;
    padding:8px 14px;
    overflow:hidden;
    border:1px solid rgba(226,232,240,.88);
    border-radius:19px;
    background:linear-gradient(160deg,rgba(255,255,255,.99),rgba(248,250,252,.96));
    box-shadow:0 8px 24px rgba(15,23,42,.065);
  }

  table.mobile-card-table td{
    display:grid;
    grid-template-columns:minmax(88px,38%) minmax(0,1fr);
    align-items:start;
    gap:10px;
    width:100%!important;
    min-width:0!important;
    padding:10px 0!important;
    border:0!important;
    border-bottom:1px solid rgba(226,232,240,.72)!important;
    text-align:right!important;
    line-height:1.45;
    overflow-wrap:anywhere;
    word-break:break-word;
    white-space:normal!important;
    color:#101828;
  }

  table.mobile-card-table td::before{
    content:attr(data-label);
    min-width:0;
    color:#8a94a6;
    font-size:11px;
    font-weight:750;
    letter-spacing:.01em;
    text-align:left;
  }

  table.mobile-card-table td:first-child{
    grid-template-columns:1fr;
    padding:11px 0 12px!important;
    text-align:left!important;
    color:#0f172a;
    font-size:16px;
    font-weight:800;
  }

  table.mobile-card-table td:first-child::before{
    display:block;
    margin-bottom:3px;
    color:#0a84ff;
    font-size:10px;
    font-weight:800;
    text-transform:none;
  }

  table.mobile-card-table td:last-child{
    border-bottom:0!important;
  }

  table.mobile-card-table td.mobile-actions{
    display:flex;
    justify-content:flex-end;
    align-items:center;
    gap:8px;
    padding-top:12px!important;
  }

  table.mobile-card-table td.mobile-actions::before{
    display:none;
  }

  table.mobile-card-table td.mobile-actions .btn,
  table.mobile-card-table td.mobile-actions a,
  table.mobile-card-table td.mobile-actions button{
    width:auto!important;
    min-height:40px;
    padding:9px 14px;
    border-radius:13px;
    font-size:12px;
  }

  table.mobile-card-table td[data-empty="true"]{
    display:none!important;
  }

  /* Compact summary tables with very few columns */
  table.mobile-card-table.mobile-compact-table tr{
    padding:7px 13px;
  }

  table.mobile-card-table.mobile-compact-table td{
    padding:8px 0!important;
  }

  .card:has(table.mobile-card-table){
    overflow:visible;
  }
}

@media (max-width: 390px) {
  table.mobile-card-table tr{padding:7px 12px;border-radius:17px}
  table.mobile-card-table td{grid-template-columns:minmax(78px,36%) minmax(0,1fr);gap:8px;font-size:12px}
  table.mobile-card-table td:first-child{font-size:15px}
}

/* ========================================================================== 
   Overflow-proof responsive tables v2
   Fixes legacy tables without thead and prevents LINE Mini App side overflow.
   ========================================================================== */
html,body,.app-shell,.main,.grid,.split,.card,.table-wrap{max-width:100%;min-width:0}
.card,.grid>*,.split>*{min-width:0!important}
.table-wrap{width:100%;max-width:100%;overflow-x:auto;overflow-y:hidden}
.table-wrap table.responsive-data-table{width:100%;max-width:100%;table-layout:auto}
.table-wrap table.responsive-data-table th,
.table-wrap table.responsive-data-table td{max-width:420px;overflow-wrap:anywhere;word-break:break-word}

@media (max-width:720px){
  .table-wrap{
    display:block!important;
    width:100%!important;
    max-width:100%!important;
    min-width:0!important;
    margin:0!important;
    padding:0!important;
    overflow:visible!important;
    contain:layout paint;
  }

  table.responsive-data-table.mobile-card-table{
    display:block!important;
    width:100%!important;
    max-width:100%!important;
    min-width:0!important;
    table-layout:fixed!important;
    border-collapse:separate!important;
    border-spacing:0!important;
  }

  table.responsive-data-table.mobile-card-table thead,
  table.responsive-data-table.mobile-card-table .mobile-table-header-row{
    position:absolute!important;
    width:1px!important;
    height:1px!important;
    margin:-1px!important;
    padding:0!important;
    overflow:hidden!important;
    clip:rect(0 0 0 0)!important;
    clip-path:inset(50%)!important;
    white-space:nowrap!important;
    border:0!important;
  }

  table.responsive-data-table.mobile-card-table tbody{
    display:grid!important;
    grid-template-columns:minmax(0,1fr)!important;
    width:100%!important;
    max-width:100%!important;
    min-width:0!important;
    gap:12px!important;
  }

  table.responsive-data-table.mobile-card-table tr.mobile-data-row{
    display:block!important;
    width:100%!important;
    max-width:100%!important;
    min-width:0!important;
    margin:0!important;
    padding:9px 13px!important;
    overflow:hidden!important;
    border:1px solid rgba(226,232,240,.92)!important;
    border-radius:20px!important;
    background:linear-gradient(160deg,#fff,#f8fafc)!important;
    box-shadow:0 8px 22px rgba(15,23,42,.065)!important;
  }

  table.responsive-data-table.mobile-card-table td{
    display:grid!important;
    grid-template-columns:minmax(76px,34%) minmax(0,1fr)!important;
    align-items:start!important;
    width:100%!important;
    max-width:100%!important;
    min-width:0!important;
    margin:0!important;
    padding:9px 0!important;
    gap:10px!important;
    border:0!important;
    border-bottom:1px solid rgba(226,232,240,.72)!important;
    text-align:left!important;
    white-space:normal!important;
    overflow:hidden!important;
  }

  table.responsive-data-table.mobile-card-table td::before{
    content:attr(data-label)!important;
    display:block!important;
    width:100%!important;
    min-width:0!important;
    color:#8a94a6!important;
    font-size:11px!important;
    font-weight:750!important;
    line-height:1.4!important;
    text-align:left!important;
    overflow-wrap:anywhere!important;
  }

  table.responsive-data-table.mobile-card-table .mobile-cell-value{
    display:block!important;
    width:100%!important;
    max-width:100%!important;
    min-width:0!important;
    color:#101828!important;
    font-size:13px!important;
    line-height:1.5!important;
    text-align:right!important;
    white-space:normal!important;
    overflow-wrap:anywhere!important;
    word-break:break-word!important;
  }

  table.responsive-data-table.mobile-card-table .mobile-cell-value *,
  table.responsive-data-table.mobile-card-table .mobile-cell-value a,
  table.responsive-data-table.mobile-card-table .mobile-cell-value button,
  table.responsive-data-table.mobile-card-table .mobile-cell-value form{
    max-width:100%!important;
    min-width:0!important;
  }

  table.responsive-data-table.mobile-card-table td:first-child{
    display:block!important;
    padding:11px 0 12px!important;
  }

  table.responsive-data-table.mobile-card-table td:first-child::before{
    margin-bottom:3px!important;
    color:#0a84ff!important;
    font-size:10px!important;
  }

  table.responsive-data-table.mobile-card-table td:first-child .mobile-cell-value{
    color:#0f172a!important;
    font-size:16px!important;
    font-weight:800!important;
    text-align:left!important;
  }

  table.responsive-data-table.mobile-card-table td:last-child{border-bottom:0!important}
  table.responsive-data-table.mobile-card-table td[data-empty="true"]{display:none!important}

  table.responsive-data-table.mobile-card-table td.mobile-actions{
    display:block!important;
    padding:12px 0 4px!important;
    overflow:visible!important;
  }
  table.responsive-data-table.mobile-card-table td.mobile-actions::before{display:none!important}
  table.responsive-data-table.mobile-card-table td.mobile-actions .mobile-cell-value{
    display:flex!important;
    flex-wrap:wrap!important;
    justify-content:flex-end!important;
    align-items:center!important;
    gap:8px!important;
    text-align:right!important;
  }
  table.responsive-data-table.mobile-card-table td.mobile-actions .btn,
  table.responsive-data-table.mobile-card-table td.mobile-actions a,
  table.responsive-data-table.mobile-card-table td.mobile-actions button{
    flex:0 1 auto!important;
    width:auto!important;
    max-width:100%!important;
    min-width:72px!important;
    min-height:39px!important;
    padding:8px 13px!important;
    white-space:normal!important;
  }

  /* Any old desktop min-width declaration must never win on a phone. */
  .table-wrap table,
  .card table{
    min-width:0!important;
    max-width:100%!important;
  }
}

@media (max-width:390px){
  table.responsive-data-table.mobile-card-table tr.mobile-data-row{padding:8px 11px!important;border-radius:18px!important}
  table.responsive-data-table.mobile-card-table td{grid-template-columns:minmax(68px,32%) minmax(0,1fr)!important;gap:8px!important}
  table.responsive-data-table.mobile-card-table .mobile-cell-value{font-size:12px!important}
}


/* ========================================================================== 
   Mobile table UX v3 — clean cards, no squeezed headers, no horizontal scroll
   ========================================================================== */
@media (max-width:720px){
  /* Empty datasets: the empty-state below the table is enough. */
  .table-wrap.is-empty-table table.empty-data-table{
    display:none!important;
  }

  .table-wrap.is-empty-table{
    min-height:0!important;
    overflow:visible!important;
  }

  .table-wrap.is-empty-table + .empty,
  .table-wrap .empty{
    display:flex;
    min-height:190px;
    align-items:center;
    justify-content:center;
    padding:30px 18px;
    border:1px dashed rgba(148,163,184,.38);
    border-radius:22px;
    background:linear-gradient(160deg,rgba(248,250,252,.92),rgba(255,255,255,.98));
    color:#8a94a6;
    font-size:14px;
    text-align:center;
  }

  /* Some pages place .empty inside .table-wrap after the table. */
  .table-wrap.is-empty-table > .empty{
    margin:2px 0 0;
  }

  /* Real mobile cards. Never expose table header or desktop table geometry. */
  table.responsive-data-table.mobile-card-table{
    border:0!important;
    background:transparent!important;
  }

  table.responsive-data-table.mobile-card-table tbody{
    gap:10px!important;
  }

  table.responsive-data-table.mobile-card-table tr.mobile-data-row{
    padding:10px 14px!important;
    border:1px solid rgba(226,232,240,.82)!important;
    border-radius:22px!important;
    background:#fff!important;
    box-shadow:0 10px 30px rgba(15,23,42,.07)!important;
  }

  table.responsive-data-table.mobile-card-table td{
    grid-template-columns:minmax(92px,36%) minmax(0,1fr)!important;
    gap:12px!important;
    padding:10px 0!important;
  }

  table.responsive-data-table.mobile-card-table td::before{
    font-size:11px!important;
    line-height:1.35!important;
    word-break:normal!important;
    overflow-wrap:break-word!important;
  }

  table.responsive-data-table.mobile-card-table .mobile-cell-value{
    font-size:13px!important;
    line-height:1.45!important;
    word-break:normal!important;
    overflow-wrap:anywhere!important;
  }

  table.responsive-data-table.mobile-card-table td:first-child{
    margin:-1px 0 2px;
    padding:12px 0 14px!important;
    border-bottom:1px solid rgba(226,232,240,.85)!important;
  }

  table.responsive-data-table.mobile-card-table td:first-child::before{
    margin-bottom:5px!important;
    font-size:10px!important;
    letter-spacing:.04em!important;
  }

  table.responsive-data-table.mobile-card-table td:first-child .mobile-cell-value{
    font-size:17px!important;
    line-height:1.35!important;
  }

  /* Compact page cards and prevent the floating nav covering controls. */
  .main{
    padding-bottom:calc(118px + env(safe-area-inset-bottom))!important;
  }

  .grid.split{
    gap:14px!important;
  }

  .card{
    padding:18px!important;
    border-radius:24px!important;
  }

  .section-head{
    gap:10px!important;
    margin-bottom:15px!important;
  }

  .section-head h2{
    font-size:20px!important;
    line-height:1.3!important;
  }

  .badge{
    flex:0 0 auto;
    max-width:100%;
    white-space:nowrap;
  }
}

@media (max-width:390px){
  table.responsive-data-table.mobile-card-table td{
    grid-template-columns:minmax(86px,38%) minmax(0,1fr)!important;
    gap:9px!important;
  }
  .card{padding:16px!important;border-radius:22px!important}
}
