:root{--bg:#020617;--panel:rgba(15,23,42,.88);--card:rgba(17,24,39,.94);--soft:rgba(30,41,59,.72);--text:#f8fafc;--muted:#94a3b8;--line:rgba(148,163,184,.18);--blue:#60a5fa;--green:#34d399;--red:#fb7185;--yellow:#fbbf24;--purple:#c084fc}*{box-sizing:border-box}html,body{min-height:100%}body{margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:radial-gradient(circle at 10% 0%,rgba(96,165,250,.22),transparent 34%),radial-gradient(circle at 92% 8%,rgba(192,132,252,.18),transparent 30%),linear-gradient(135deg,#020617,#0f172a 55%,#111827);color:var(--text)}.app-shell{max-width:1220px;margin:0 auto;padding:24px 22px 104px}.topbar{position:sticky;top:0;z-index:10;margin:0 0 22px;padding:16px 18px;display:flex;align-items:center;justify-content:space-between;gap:16px;background:rgba(2,6,23,.78);backdrop-filter:blur(16px);border:1px solid var(--line);border-radius:0 0 18px 18px}.brand{display:flex;gap:13px;align-items:center}.logo{width:48px;height:48px;border-radius:18px;display:grid;place-items:center;background:linear-gradient(135deg,rgba(96,165,250,.25),rgba(192,132,252,.18));border:1px solid var(--line);font-size:24px}.brand h1{margin:0;font-size:clamp(22px,4vw,31px);letter-spacing:-.03em}.brand p{margin:4px 0 0;color:var(--muted);font-size:13px}.badges{display:flex;gap:9px;flex-wrap:wrap}.badge{padding:8px 12px;border-radius:999px;background:var(--soft);color:var(--muted);font-size:13px;border:1px solid var(--line)}.badge.on{color:#dcfce7;background:rgba(34,197,94,.18);border-color:rgba(34,197,94,.42)}.badge.off{color:#ffe4e6;background:rgba(244,63,94,.18);border-color:rgba(244,63,94,.42)}.notice{padding:13px 15px;border-radius:16px;margin-bottom:16px}.warn{background:rgba(251,191,36,.14);border:1px solid rgba(251,191,36,.35);color:#fde68a}.danger.notice{background:rgba(251,113,133,.14);border:1px solid rgba(251,113,133,.38);color:#ffe4e6}.dashboard{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px;margin-bottom:18px}.stat-card{background:rgba(15,23,42,.72);border:1px solid var(--line);border-radius:20px;padding:17px;box-shadow:0 16px 40px rgba(0,0,0,.22)}.stat-card span{display:block;color:var(--muted);font-size:12px}.stat-card strong{display:block;margin-top:7px;font-size:24px;letter-spacing:-.03em}.grid.two{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:18px;margin-bottom:18px}.card{background:var(--card);border:1px solid var(--line);border-radius:24px;padding:20px;box-shadow:0 18px 55px rgba(0,0,0,.28)}.card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:14px}.card-head h2{margin:0;font-size:20px}.card-head span,.card-head p{margin:4px 0 0;color:var(--muted);font-size:12px}.token-row,.button-row,.toolbar{display:flex;gap:10px;flex-wrap:wrap}.button-row{margin-top:10px}.token-row input{flex:1;min-width:210px}.button-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.button-grid.compact{grid-template-columns:repeat(auto-fit,minmax(130px,1fr))}.mt{margin-top:12px}.grow{flex:1}button,input,select,.btn{border:1px solid var(--line);background:var(--soft);color:var(--text);border-radius:14px;padding:12px 14px;font-size:14px;min-height:44px;text-decoration:none}button,.btn{cursor:pointer;transition:.14s ease;text-align:center;touch-action:manipulation}button:active,.btn:active{transform:scale(.98)}.btn.primary{background:rgba(96,165,250,.22);border-color:rgba(96,165,250,.46)}.btn.success{background:rgba(52,211,153,.20);border-color:rgba(52,211,153,.46)}.btn.danger{background:rgba(251,113,133,.20);border-color:rgba(251,113,133,.46)}.btn.warning{background:rgba(251,191,36,.20);border-color:rgba(251,191,36,.46)}.btn.purple{background:rgba(192,132,252,.20);border-color:rgba(192,132,252,.46)}.btn.big{width:100%;font-weight:800}.btn.small{font-size:12px;padding:8px 10px;min-height:36px;border-radius:12px}.hint,.mini-result{color:var(--muted);font-size:12px;margin:10px 0 0}.upload-zone input[type=file]{width:100%;background:rgba(15,23,42,.8)}.ocr-rule{margin:12px 0;padding:12px 13px;border-radius:16px;background:rgba(96,165,250,.10);border:1px solid rgba(96,165,250,.22);color:#cbd5e1;font-size:13px;line-height:1.55}.image-rows{display:flex;flex-direction:column;gap:9px;margin:12px 0}.image-row{display:grid;grid-template-columns:34px 1fr 70px 82px;align-items:center;gap:9px;padding:11px;border:1px solid var(--line);background:rgba(30,41,59,.52);border-radius:16px}.file-no{width:28px;height:28px;border-radius:10px;display:grid;place-items:center;background:rgba(96,165,250,.18);font-weight:800}.file-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#e2e8f0}.file-size{color:var(--muted);font-size:12px;text-align:right}.file-status{font-size:12px;color:var(--muted);text-align:center}.file-status.doing{color:#fde68a}.file-status.ok{color:#86efac}.file-status.fail{color:#fda4af}.result{white-space:pre-wrap;color:#d1fae5;font-size:13px;margin-top:12px;background:rgba(6,78,59,.16);border:1px solid rgba(16,185,129,.22);border-radius:16px;padding:13px;min-height:44px;max-height:280px;overflow:auto}.result.loading{color:#fde68a;background:rgba(113,63,18,.16);border-color:rgba(251,191,36,.25)}.boss-head{align-items:center}.toolbar{justify-content:flex-end}.toolbar input{min-width:190px}.boss-list{display:flex;flex-direction:column;gap:12px;max-height:660px;overflow:auto;padding-right:4px}.boss-row{display:grid;grid-template-columns:minmax(180px,1.2fr) minmax(135px,.55fr) auto;gap:14px;align-items:center;background:rgba(30,41,59,.62);border:1px solid var(--line);border-radius:18px;padding:14px}.boss-name{font-weight:900;font-size:15px}.boss-meta{color:var(--muted);font-size:12px;margin-top:6px;word-break:break-all}.boss-timebox strong{display:block;font-variant-numeric:tabular-nums}.boss-timebox span{display:block;color:#bfdbfe;font-size:12px;margin-top:5px}.actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.empty{color:var(--muted);padding:22px;text-align:center;border:1px dashed var(--line);border-radius:18px}.footer{color:var(--muted);font-size:12px;text-align:center;margin-top:20px}.bottom-nav{position:fixed;left:0;right:0;bottom:0;z-index:20;display:none;grid-template-columns:repeat(4,1fr);gap:8px;padding:10px;background:rgba(2,6,23,.86);backdrop-filter:blur(16px);border-top:1px solid var(--line)}.bottom-nav button{min-height:48px;font-size:12px;padding:8px 4px}.section-anchor{scroll-margin-top:104px}@media(max-width:900px){.topbar{align-items:flex-start;flex-direction:column}.badges{width:100%}.badge{flex:1;text-align:center}.dashboard{grid-template-columns:repeat(2,minmax(0,1fr))}.grid.two{grid-template-columns:1fr}.boss-head{align-items:stretch;flex-direction:column}.toolbar>*{flex:1;min-width:132px}.boss-row{grid-template-columns:1fr}.actions{justify-content:stretch}.actions button{flex:1}.bottom-nav{display:grid}}@media(max-width:520px){.app-shell{padding:16px 14px 96px}.topbar{margin:0 0 16px;padding:14px}.card{border-radius:20px;padding:16px}.dashboard{gap:10px}.stat-card{padding:14px}.button-grid.compact{grid-template-columns:1fr 1fr}.image-row{grid-template-columns:28px 1fr 66px}.file-status{grid-column:2/4;text-align:left}.toolbar input,.toolbar select,.toolbar button{min-width:100%;}.brand p{display:none}}
.user-list{margin-top:10px;display:flex;flex-direction:column;gap:8px}
.user-list-title{font-size:12px;color:#cbd5e1;font-weight:900}
.user-row{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center;padding:10px;border:1px solid var(--line);border-radius:14px;background:rgba(30,41,59,.48)}
.user-row strong{display:block;font-size:14px}
.user-row span{display:block;margin-top:3px;color:var(--muted);font-size:12px;word-break:break-all}
.role-pill{display:inline-flex;margin-left:8px;padding:4px 8px;border-radius:999px;font-size:11px;font-weight:900;border:1px solid var(--line)}
.role-pill.member{color:#dbeafe;background:rgba(96,165,250,.18);border-color:rgba(96,165,250,.48)}
.role-pill.admin{color:#fef3c7;background:rgba(251,191,36,.18);border-color:rgba(251,191,36,.48)}
.empty.compact{padding:12px;font-size:12px}
.admin-settings-strip{margin-bottom:14px;padding:14px;border:1px solid rgba(148,163,184,.16);border-radius:18px;background:rgba(15,23,42,.55)}
.settings-strip-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:10px}
.settings-strip-head h2{margin:0;font-size:18px}
.settings-strip-head p{margin:3px 0 0;color:var(--muted);font-size:12px}
.settings-status-line{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px;color:#cbd5e1;font-size:12px;font-weight:800}.settings-status-line span{padding:7px 10px;border:1px solid var(--line);border-radius:999px;background:rgba(30,41,59,.54)}
.boss-row.spawning{background:rgba(127,29,29,.38);border-color:rgba(251,113,133,.48);box-shadow:inset 4px 0 0 rgba(251,113,133,.88)}
.spawn-badge{display:inline-flex;align-items:center;margin-left:6px;padding:3px 8px;border-radius:999px;background:rgba(251,113,133,.22);border:1px solid rgba(251,113,133,.5);color:#ffe4e6;font-size:11px;font-weight:800;vertical-align:middle}
.boss-row.spawning .boss-timebox span{color:#fecdd3;font-weight:800}
.boss-row.due-soon{background:rgba(113,63,18,.36);border-color:rgba(251,191,36,.58);box-shadow:inset 4px 0 0 rgba(251,191,36,.9)}
.boss-row.due-soon .boss-timebox span{color:#fde68a;font-weight:900}
.soon-badge{display:inline-flex;align-items:center;margin-left:6px;padding:3px 8px;border-radius:999px;background:rgba(251,191,36,.2);border:1px solid rgba(251,191,36,.55);color:#fef3c7;font-size:11px;font-weight:900;vertical-align:middle}
.boss-row.manual .boss-name{font-weight:1000;color:#fff}
.boss-row.auto .boss-name{font-weight:800}
.cut-mode-badge{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;margin-left:8px;min-width:54px;padding:5px 11px;border-radius:999px;font-size:14px;font-weight:1000;border:1px solid transparent;letter-spacing:0}
.cut-mode-badge.manual{color:#eff6ff;background:rgba(37,99,235,.35);border-color:rgba(96,165,250,.78);box-shadow:0 0 0 1px rgba(96,165,250,.14) inset}
.cut-mode-badge.auto{color:#ecfdf5;background:rgba(5,150,105,.34);border-color:rgba(52,211,153,.78);box-shadow:0 0 0 1px rgba(52,211,153,.14) inset}
.nav-badge{text-decoration:none}
.member-shell{max-width:1220px}
.member-shell .boss-head{display:flex;align-items:flex-end;gap:12px;flex-wrap:wrap}
.member-shell .boss-title-block{flex:1 0 100%;min-width:0}
.member-shell .boss-title-block h2{margin:0}
.member-shell .boss-title-block p{margin:4px 0 0}
.member-shell .boss-control-row{display:flex;align-items:center;gap:12px;flex:1 1 auto;min-width:0;justify-content:flex-start}
.member-shell .boss-search-input{flex:1 1 50%;width:50%;min-width:260px;max-width:620px}
.member-shell .boss-control-row select{flex:0 0 150px;min-width:150px}
.member-shell .boss-head .section-collapse-toggle{margin-left:0}
.member-login-grid{grid-template-columns:minmax(0,1.2fr) minmax(280px,.8fr);gap:18px}
.member-name-row{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;margin-top:12px}
.member-name-row span{padding:9px 11px;border:1px solid var(--line);border-radius:12px;background:rgba(30,41,59,.52);color:#dbeafe;font-size:12px;font-weight:900;white-space:nowrap}
.auth-guide,.auth-ok{margin-bottom:10px;padding:11px 12px;border-radius:16px;border:1px solid var(--line);background:rgba(30,41,59,.48)}
.auth-guide{border-color:rgba(251,191,36,.46);background:rgba(113,63,18,.18)}
.auth-ok{border-color:rgba(52,211,153,.46);background:rgba(6,78,59,.18)}
.auth-guide strong,.auth-ok strong{display:block;font-size:13px}
.auth-guide span,.auth-ok span{display:block;margin-top:4px;color:#cbd5e1;font-size:12px;line-height:1.45}
.member-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.member-stats>div{padding:14px;border:1px solid var(--line);border-radius:16px;background:rgba(30,41,59,.52)}
.member-stats span{display:block;color:var(--muted);font-size:12px}
.member-stats strong{display:block;margin-top:5px;font-size:24px}
.member-mode-line{display:flex;gap:8px;align-items:center;margin-top:8px}
.member-row{grid-template-columns:1fr;gap:12px;padding:16px;border-radius:20px}
.member-boss-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.member-boss-title-row .boss-name{min-width:0}
.member-row .boss-name{font-size:18px;line-height:1.25}
.member-row .boss-timebox{display:grid;grid-template-columns:1fr auto;align-items:end;padding:10px 12px;border-radius:14px;background:rgba(15,23,42,.52);border:1px solid rgba(148,163,184,.14)}
.member-row .boss-timebox strong{font-size:22px}
.member-row .boss-timebox span{text-align:right;font-size:13px}
.member-row .actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;justify-content:stretch}
.member-row .actions .btn{width:100%;min-height:46px;font-size:14px}
.alarm-check{display:inline-flex;align-items:center;gap:7px;margin-top:9px;padding:7px 10px;border:1px solid rgba(96,165,250,.38);border-radius:12px;background:rgba(96,165,250,.12);color:#dbeafe;font-size:12px;font-weight:800;cursor:pointer}
.alarm-check input{width:16px;height:16px;min-height:0;accent-color:#60a5fa}
.alarm-toggle{font-weight:900}
.alarm-toggle.on{background:rgba(96,165,250,.26);border-color:rgba(96,165,250,.72);color:#dbeafe}
.alarm-toggle.off{background:rgba(71,85,105,.48);border-color:rgba(148,163,184,.32);color:#cbd5e1}
#event-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;max-height:none;overflow:visible;padding-right:0}
#event-list .event-row{grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center;min-height:74px;padding:13px 15px;border-radius:18px}
#event-list .event-row .boss-name{font-size:16px}
#event-list .event-row .boss-meta{margin-top:5px;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#event-list .event-row .actions{display:flex;justify-content:flex-end;min-width:0}
#event-list .event-row .actions .btn{width:auto;min-width:100px;min-height:44px;padding:8px 12px;font-size:13.3px}
@media(max-width:900px){.member-login-grid{grid-template-columns:1fr}.member-stats{grid-template-columns:repeat(3,1fr)}}
@media(max-width:520px){.member-stats{grid-template-columns:1fr 1fr}.member-stats>div:first-child{grid-column:1/3}}
@media(max-width:520px){.member-name-row{grid-template-columns:1fr}.settings-strip-head{display:block}}
.admin-quick-grid{grid-template-columns:minmax(360px,.95fr) minmax(520px,1.55fr);align-items:start}
@media(max-width:1100px){.admin-quick-grid{grid-template-columns:1fr}}
@media(min-width:901px){
  .member-login-grid{grid-template-columns:minmax(360px,.9fr) minmax(520px,1.1fr);align-items:start}
  .member-shell .boss-list{max-height:760px}
  .member-row{grid-template-columns:minmax(260px,1.35fr) minmax(180px,.7fr) minmax(230px,.7fr);align-items:center}
  .member-row .boss-name{font-size:17px}
  .member-row .boss-timebox{min-height:74px}
  .member-row .actions{grid-template-columns:1fr 1fr;min-width:220px}
}
.icon-actions{align-items:center;justify-content:flex-end}
.icon-badge{width:44px;height:44px;min-width:44px;min-height:44px;padding:0;display:inline-flex;align-items:center;justify-content:center;text-align:center;border-radius:16px;font-size:18px;line-height:1;text-decoration:none;flex:0 0 44px;font-family:"Segoe UI Emoji","Apple Color Emoji","Noto Color Emoji",system-ui,sans-serif}
.icon-badge.nav-badge{background:rgba(148,163,184,.12);border-color:rgba(148,163,184,.28)}
.topbar{min-height:78px}
.topbar .badges.icon-actions{max-width:420px}
@media(min-width:1101px){.dashboard{grid-template-columns:repeat(3,minmax(0,1fr))}.admin-quick-grid{grid-template-columns:minmax(380px,.88fr) minmax(560px,1.35fr)}.boss-row{grid-template-columns:minmax(230px,1.25fr) minmax(170px,.55fr) minmax(270px,.85fr)}}
@media(min-width:701px) and (max-width:1100px){.app-shell{max-width:900px;padding:22px 20px 104px}.topbar{align-items:center}.topbar .badges.icon-actions{max-width:none}.dashboard{grid-template-columns:repeat(3,minmax(0,1fr))}.grid.two,.admin-quick-grid,.member-login-grid{grid-template-columns:1fr 1fr}.admin-quick-grid{align-items:start}.boss-row,.member-row{grid-template-columns:minmax(0,1fr) minmax(150px,.55fr);gap:12px}.boss-row .actions,.member-row .actions{grid-column:1/3;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));justify-content:stretch}.member-row .actions{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:700px){.app-shell{padding:14px 12px 96px}.topbar{position:sticky;align-items:stretch;gap:12px;padding:14px;border-radius:0 0 18px 18px}.brand{min-width:0}.logo{width:44px;height:44px;border-radius:16px}.brand h1{font-size:23px}.badges.icon-actions{display:grid;width:100%;grid-template-columns:repeat(6,1fr);gap:8px}.member-shell .badges.icon-actions{grid-template-columns:repeat(4,1fr)}.icon-badge{width:100%;min-width:0;height:42px;min-height:42px;border-radius:14px}.dashboard{grid-template-columns:1fr 1fr}.dashboard .stat-card:last-child{grid-column:1/3}.grid.two,.admin-quick-grid,.member-login-grid{grid-template-columns:1fr}.card{padding:16px;border-radius:20px}.token-row,.button-row,.toolbar{display:grid;grid-template-columns:1fr;gap:9px}.token-row input,.toolbar input,.toolbar select,.toolbar button{min-width:0;width:100%}.member-name-row{grid-template-columns:1fr}.boss-list{max-height:none;padding-right:0}.boss-row,.member-row{grid-template-columns:1fr;padding:14px}.boss-row .actions,.member-row .actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}.actions button{min-width:0}}
#event-list .event-row{grid-template-columns:minmax(0,1fr) auto!important}
#event-list .event-row .actions{display:flex!important;grid-template-columns:none!important}
@media(max-width:520px){#event-list{grid-template-columns:1fr}#event-list .event-row .actions .btn{min-width:96px}}
@media(max-width:390px){.badges.icon-actions{grid-template-columns:repeat(3,1fr)}.member-shell .badges.icon-actions{grid-template-columns:repeat(4,1fr)}.dashboard{grid-template-columns:1fr}.dashboard .stat-card:last-child{grid-column:auto}.boss-row .actions,.member-row .actions{grid-template-columns:1fr}.brand h1{font-size:21px}}
.dashboard{display:none!important}
.collapsible-body.collapsed{display:none}
.section-collapse-toggle{margin-left:auto;white-space:nowrap}
.settings-strip-head .section-collapse-toggle{align-self:flex-start}
@media(max-width:700px){
  .boss-main{min-width:0}
  .card-head,.settings-strip-head{align-items:center}
  .member-shell .boss-head{align-items:stretch}
  .member-shell .boss-title-block{flex-basis:auto}
  .member-shell .boss-control-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(124px,auto);gap:9px}
  .member-shell .boss-search-input{width:100%;min-width:0;max-width:none}
  .member-shell .boss-control-row select{width:100%;min-width:0}
}
.cut-log-tools{margin-top:12px;display:flex;gap:8px}.cut-log-tools .btn{min-height:40px;padding:9px 13px}.cut-log-panel{margin-top:10px;border:1px solid var(--line);border-radius:16px;background:rgba(15,23,42,.42);overflow:hidden}.cut-log-list{display:flex;flex-direction:column;max-height:260px;overflow:auto}.cut-log-item{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center;padding:10px 12px;border-top:1px solid var(--line)}.cut-log-item:first-child{border-top:0}.cut-log-item strong,.cut-log-item b{display:block;font-size:13px}.cut-log-item span{display:block;margin-top:3px;color:var(--muted);font-size:12px}.cut-log-item>div:last-child{text-align:right}@media(max-width:520px){.cut-log-item{grid-template-columns:1fr}.cut-log-item>div:last-child{text-align:left}}
.boss-group{display:flex;flex-direction:column;gap:10px}.boss-group+.boss-group{margin-top:10px}.boss-group-title{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 10px;border:1px solid var(--line);border-radius:12px;background:rgba(15,23,42,.56);color:#dbeafe;font-size:13px;font-weight:900}.boss-group-title b{min-width:28px;text-align:center;padding:3px 8px;border-radius:999px;background:rgba(96,165,250,.20);color:#bfdbfe}
.quick-action{width:auto;min-width:78px;height:48px;min-height:48px;gap:6px;padding:7px 10px;border-radius:14px;flex:0 0 auto;font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}.quick-icon{font-family:"Segoe UI Emoji","Apple Color Emoji","Noto Color Emoji",system-ui,sans-serif;font-size:17px;line-height:1}.quick-label{font-size:12px;font-weight:900;line-height:1;white-space:nowrap}.image-save-badge{background:rgba(96,165,250,.24);border-color:rgba(96,165,250,.55);color:#dbeafe}.topbar .badges.icon-actions{max-width:none}@media(max-width:700px){.badges.icon-actions{grid-template-columns:repeat(3,1fr)}.member-shell .badges.icon-actions{grid-template-columns:repeat(2,1fr)}.quick-action{width:100%;min-width:0;height:44px;min-height:44px}.quick-label{font-size:11px}}@media(max-width:390px){.badges.icon-actions{grid-template-columns:repeat(2,1fr)}.member-shell .badges.icon-actions{grid-template-columns:repeat(2,1fr)}}
.member-row .boss-timebox{min-width:220px}.member-row .boss-timebox strong{white-space:nowrap}.member-row .boss-timebox span{white-space:nowrap}@media(min-width:901px){.member-row{grid-template-columns:minmax(240px,1.1fr) minmax(220px,.8fr) minmax(230px,.7fr)}.member-row .boss-timebox{min-width:220px}}@media(min-width:701px) and (max-width:1100px){.member-row{grid-template-columns:minmax(0,1fr) minmax(220px,.7fr)}.member-row .boss-timebox{min-width:220px}}
.image-save-badge{display:inline-flex!important;visibility:visible!important}.floating-save-button{position:fixed;right:14px;bottom:78px;z-index:45;display:inline-flex;align-items:center;gap:8px;min-height:46px;padding:11px 14px;border-radius:16px;border:1px solid rgba(96,165,250,.58);background:rgba(30,64,175,.92);color:#eff6ff;text-decoration:none;box-shadow:0 18px 42px rgba(0,0,0,.34);font-size:13px;font-weight:900;backdrop-filter:blur(14px)}.floating-save-button span{font-family:"Segoe UI Emoji","Apple Color Emoji","Noto Color Emoji",system-ui,sans-serif}.floating-save-button b{font-size:13px;line-height:1;white-space:nowrap}@media(min-width:701px){.floating-save-button{bottom:24px}}@media(max-width:390px){.floating-save-button{right:10px;bottom:72px;padding:10px 12px}.floating-save-button b{font-size:12px}}

.floating-top-button{position:fixed;right:14px;bottom:132px;z-index:45;display:inline-flex;align-items:center;gap:8px;min-height:46px;padding:11px 14px;border-radius:16px;border:1px solid rgba(148,163,184,.42);background:rgba(15,23,42,.92);color:#eff6ff;text-decoration:none;box-shadow:0 18px 42px rgba(0,0,0,.34);font-size:13px;font-weight:900;backdrop-filter:blur(14px)}.floating-top-button span{font-size:17px;line-height:1;font-weight:900}.floating-top-button b{font-size:13px;line-height:1;white-space:nowrap}@media(min-width:701px){.floating-top-button{bottom:78px}}@media(max-width:390px){.floating-top-button{right:10px;bottom:124px;padding:10px 12px}.floating-top-button b{font-size:12px}}
.member-save-button{display:inline-flex;align-items:center;justify-content:center}
@media(orientation:landscape) and (max-height:620px){
  .app-shell{max-width:none;width:100%;padding:8px 10px 66px}
  .topbar{position:relative;min-height:auto;margin-bottom:10px;padding:10px 12px;gap:10px;border-radius:0 0 14px 14px}
  .logo{width:38px;height:38px;border-radius:13px;font-size:20px}
  .brand h1{font-size:20px;letter-spacing:0}
  .brand p{display:none}
  .card{padding:12px;border-radius:16px}
  .grid.two,.admin-quick-grid,.member-login-grid{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
  .card-head{margin-bottom:9px}
  .card-head h2{font-size:17px}
  button,input,select,.btn{min-height:40px;padding:9px 11px;font-size:13px;border-radius:12px}
  .button-grid.compact{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}
  .member-stats{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
  .member-stats>div{padding:10px;border-radius:12px}
  .member-stats strong{font-size:19px}
  .member-row,.boss-row{grid-template-columns:minmax(180px,1.15fr) minmax(180px,.75fr) minmax(180px,.7fr);gap:8px;padding:10px;border-radius:14px}
  .member-row .boss-name{font-size:15px}
  .member-row .boss-timebox{min-width:0;min-height:54px;padding:8px 10px}
  .member-row .boss-timebox strong{font-size:17px}
  .member-row .actions{grid-template-columns:1fr 1fr;min-width:0}
  .boss-list{max-height:none;gap:8px}
  #event-list{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
  .floating-save-button{right:10px;bottom:66px;min-height:40px;padding:9px 11px}
  .floating-top-button{right:10px;bottom:112px;min-height:40px;padding:9px 11px}
  .bottom-nav{display:grid;padding:7px;gap:6px}
  .bottom-nav button{min-height:40px}
}
@media(max-width:430px),(max-height:460px){
  .topbar .badges.icon-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));width:100%;gap:7px}
  .quick-action,.icon-badge{width:100%;min-width:0}
  .button-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}
  .button-row .btn,.button-row button{width:100%}
  .member-shell .boss-control-row{display:grid;grid-template-columns:1fr;gap:8px}
  .member-shell .boss-control-row select,.member-shell .boss-search-input{width:100%;min-width:0;max-width:none}
}

.member-shell{padding-bottom:118px}
.member-shell .topbar .badges.icon-actions{grid-template-columns:repeat(2,minmax(0,1fr))}
.member-shell .quick-action.off .quick-icon{color:#fb7185}
.member-shell .quick-action.on .quick-icon{color:#34d399}
.connection-badge{--connection-color:#fb7185}
.connection-badge.on{--connection-color:#34d399}
.connection-badge.off{--connection-color:#fb7185}
.connection-icon{display:inline-block;width:1em;height:1em;border-radius:50%;background:var(--connection-color);flex:0 0 auto;box-shadow:0 0 10px color-mix(in srgb,var(--connection-color) 28%,transparent)}
.connection-icon::after{content:none}
.member-shell .boss-title-block{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex:1 0 100%}
.member-shell .boss-title-block>div{min-width:0}
.boss-refresh-button{flex:0 0 auto;min-height:40px;padding:9px 12px}
.member-slide-panels{position:relative;z-index:50}
.member-panel-backdrop{position:fixed;inset:0;z-index:49;background:rgba(2,6,23,.38);backdrop-filter:blur(2px)}
.member-slide-panel{position:fixed;left:50%;right:auto;bottom:74px;z-index:50;width:min(720px,calc(100vw - 24px));max-height:min(72vh,680px);overflow:auto;transform:translate(-50%,calc(100% + 96px));opacity:0;pointer-events:none;transition:transform .22s ease,opacity .18s ease;border-radius:22px;box-shadow:0 24px 70px rgba(0,0,0,.48)}
.member-slide-panel.open{transform:translate(-50%,0);opacity:1;pointer-events:auto}
.member-slide-panel .card-head{position:sticky;top:0;z-index:1;margin:-20px -20px 14px;padding:16px 20px 12px;background:rgba(17,24,39,.96);border-bottom:1px solid var(--line);border-radius:22px 22px 0 0}
.member-floating-nav{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:6px;padding:8px calc(8px + env(safe-area-inset-right)) calc(8px + env(safe-area-inset-bottom)) calc(8px + env(safe-area-inset-left));background:rgba(2,6,23,.92)}
.member-floating-nav button{min-width:0;min-height:48px;padding:7px 4px;border-radius:13px;font-size:11.5px;font-weight:900;white-space:normal;line-height:1.15}
.member-floating-nav button.active{background:rgba(96,165,250,.26);border-color:rgba(96,165,250,.72);color:#eff6ff}
.member-shell .member-mode-line{display:flex}
.member-shell #event-list{grid-template-columns:1fr}
.member-shell .member-stats{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
.member-shell .member-stats>div{min-width:0;padding:8px 9px;border-radius:12px}
.member-shell .member-stats strong{font-size:18px}
.member-shell .member-stats span{font-size:11px}
.member-shell .boss-head .section-collapse-toggle{margin-left:auto}
.user-row{grid-template-columns:minmax(0,1fr) auto;align-items:center}
.user-main{min-width:0}
.user-main strong{display:block;overflow:hidden;text-overflow:ellipsis;white-space:normal;line-height:1.25}
.user-main span{display:block;margin-top:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.user-actions{grid-column:1/3;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:7px}
.user-action{width:100%;min-width:0;white-space:nowrap}
.user-list{gap:10px}
.user-row{padding:13px;grid-template-columns:minmax(0,1fr) auto}
.user-main strong{font-size:15px}
.user-main .user-full-id{margin-top:6px;color:#dbeafe;font-size:12.5px;font-weight:800;white-space:normal;word-break:break-all}
.user-badges{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}
.user-actions{grid-template-columns:repeat(5,minmax(0,1fr))}
@media(max-width:620px){
  .user-row{grid-template-columns:1fr}
  .user-badges{justify-content:flex-start}
  .user-actions{grid-column:auto;grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media(max-width:700px){
  .member-shell{padding-bottom:96px}
  .member-shell .boss-title-block{align-items:center}
  .member-shell .boss-control-row{grid-template-columns:minmax(0,1fr) minmax(124px,auto)}
  .member-slide-panel{bottom:70px;width:calc(100vw - 20px);max-height:72vh;border-radius:20px}
  .member-slide-panel .card-head{margin:-16px -16px 12px;padding:14px 16px 10px;border-radius:20px 20px 0 0}
  .member-shell .member-stats{grid-template-columns:repeat(3,minmax(0,1fr))}
  .member-shell .member-stats>div:first-child{grid-column:auto}
  .member-floating-nav{display:grid;grid-template-columns:repeat(5,minmax(0,1fr))}
  .member-floating-nav button{min-height:46px;font-size:10.5px}
}
@media(max-width:390px){
  .member-floating-nav{gap:5px;padding-left:6px;padding-right:6px}
  .member-floating-nav button{font-size:10px;padding-left:2px;padding-right:2px}
}
.member-shell #status-section .member-stats{grid-template-columns:repeat(3,minmax(0,1fr))}
.member-shell #status-section .member-stats>div:first-child{grid-column:auto}
@media(max-width:520px){
  .member-shell #status-section .member-stats{grid-template-columns:repeat(3,minmax(0,1fr))!important;gap:6px}
  .member-shell #status-section .member-stats>div{grid-column:auto!important;padding:7px 7px}
  .member-shell #status-section .member-stats span{font-size:10px}
  .member-shell #status-section .member-stats strong{font-size:17px}
}
#upload-section{align-self:start}
#upload-section .ocr-rule{margin:8px 0;padding:9px 10px;border-radius:12px;font-size:12px;line-height:1.42}
#upload-section .button-row{margin-top:8px}
#upload-section .result{max-height:170px}
#upload-section .image-rows{max-height:220px;overflow:auto}

/* OCR 파일 선택: 숨김 라벨 방식 대신 브라우저 기본 file input을 그대로 보이게 유지 */
#upload-section .ocr-file-picker{display:grid;grid-template-columns:minmax(0,1fr) minmax(96px,.32fr) minmax(0,.7fr);gap:8px;align-items:center;margin:4px 0 8px;min-width:0}
#upload-section .ocr-file-input{position:static!important;display:block!important;width:100%!important;height:auto!important;min-height:44px!important;padding:10px 12px!important;margin:0!important;overflow:visible!important;clip:auto!important;white-space:normal!important;border:1px solid var(--line)!important;background:rgba(15,23,42,.8)!important;color:var(--text)!important;border-radius:14px!important}
#upload-section .ocr-file-summary{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--muted);font-size:12px;padding:0 4px}
@media(max-width:700px){#upload-section .ocr-file-picker{grid-template-columns:1fr}#upload-section .ocr-file-summary{white-space:normal}}

/* OCR 등록 영역: 파일 목록이 카드 밖으로 넘치지 않도록 컴팩트/내부 스크롤 처리 */
#upload-section{min-width:0;overflow:hidden}
#upload-section .upload-zone,#upload-section form{min-width:0;max-width:100%;overflow:hidden}
#upload-section .button-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
#upload-section .button-row>*{min-width:0;width:100%;max-width:100%}
#upload-section .image-rows{max-height:155px;overflow:auto;overscroll-behavior:contain;padding-right:2px}
#upload-section .image-row{grid-template-columns:32px minmax(0,1fr) 58px minmax(82px,.28fr) 48px;gap:7px;padding:9px;min-width:0}
#upload-section .file-name{min-width:0}
#upload-section .file-size,#upload-section .file-status{font-size:11px}
#upload-section .file-region,#upload-section .ocr-region-select{min-width:0;width:100%;max-width:100%;font-size:12px;padding-left:8px;padding-right:8px}
#upload-section .result{max-height:120px;overflow:auto}
@media(max-width:700px){#upload-section .button-row{grid-template-columns:1fr}#upload-section .image-rows{max-height:130px}#upload-section .image-row{grid-template-columns:28px minmax(0,1fr) 56px}#upload-section .image-row .file-region,#upload-section .image-row .ocr-region-select{grid-column:2/4}#upload-section .image-row .file-status{grid-column:2/4;text-align:left}}


/* TFBot admin quick menu popup: collapsed by default so it does not cover the screen. */
.quick-menu-wrap{
  position:fixed;
  right:16px;
  bottom:calc(16px + env(safe-area-inset-bottom,0px));
  z-index:80;
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:10px;
  pointer-events:none;
}
.quick-menu-button{
  pointer-events:auto;
  border:1px solid rgba(148,163,184,.34);
  background:linear-gradient(135deg,rgba(37,99,235,.96),rgba(14,165,233,.94));
  color:white;
  box-shadow:0 18px 45px rgba(15,23,42,.28);
  border-radius:999px;
  padding:11px 14px;
  min-width:108px;
  min-height:46px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  font-weight:900;
  cursor:pointer;
}
.quick-menu-button span{font-size:18px;line-height:1}
.quick-menu-button b{font-size:13px;line-height:1;white-space:nowrap}
.quick-menu-panel{
  pointer-events:auto;
  min-width:164px;
  padding:10px;
  border-radius:18px;
  border:1px solid var(--line);
  background:rgba(15,23,42,.96);
  box-shadow:0 20px 50px rgba(15,23,42,.38);
  backdrop-filter:blur(16px);
  display:grid;
  grid-template-columns:1fr;
  gap:8px;
}
body.light .quick-menu-panel{background:rgba(255,255,255,.98)}
.quick-menu-panel[hidden]{display:none!important}
.quick-menu-panel button{
  border:1px solid var(--line);
  background:var(--soft);
  color:var(--text);
  border-radius:13px;
  min-height:42px;
  padding:9px 12px;
  font-weight:900;
  cursor:pointer;
  text-align:left;
}
.quick-menu-panel button:hover{filter:brightness(1.05)}
/* Admin quick menu uses its own popup; do not hide the member bottom nav. */
.logo{font-size:17px;letter-spacing:-.06em}
@media(max-width:700px){
  .quick-menu-wrap{right:12px;bottom:calc(12px + env(safe-area-inset-bottom,0px))}
  .quick-menu-button{min-width:96px;min-height:44px;padding:10px 12px}
  .quick-menu-panel{min-width:148px;border-radius:16px}
  .app-shell:not(.member-shell){padding-bottom:72px}
}
