@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@300;400;500;600;700&family=DM+Sans:wght@400;500;600;700&display=swap');
:root{
  --pr:#2B5CE6;--pr-l:#EEF2FF;--pr-d:#1E40AF;--brand-color:#2B5CE6;
  --bg:#F5F6FA;--sf:#FFF;--sf2:#F1F3F7;--bd:#E4E7EE;--bdl:#F0F2F7;
  --t1:#111827;--t2:#6B7280;--t3:#9CA3AF;
  --ok:#10B981;--okl:#D1FAE5;--wa:#F59E0B;--wal:#FEF3C7;--er:#EF4444;--erl:#FEE2E2;
  --sw:220px;--hh:52px;--r:8px;--rl:10px;--control-h:36px;--control-font-size:13px;--control-radius:6px;--control-border:#e4e7ee;--control-padding-x:9px;
  --sh:0 1px 3px rgba(0,0,0,.07);--shm:0 4px 14px rgba(0,0,0,.1);
  --z-sidebar:1000;--z-modal:3000;--z-dropdown:4000;--z-popover:5000;--z-viewer:6000;--z-toast:7000;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Noto Sans KR',sans-serif;background:var(--bg);color:var(--t1);font-size:13px;line-height:1.55}

/* ── LOGIN ── */
.login-wrap{display:flex;height:100vh;overflow:hidden}
.login-left{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px;background:var(--sf)}
.login-logo{display:flex;align-items:center;gap:12px;margin-bottom:40px}
.login-logo-mark{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;background:#fff;border:1px solid var(--bd)}
.login-logo-mark img{width:100%;height:100%;object-fit:contain;display:block}
.login-logo-text{font-size:20px;font-weight:700;letter-spacing:-.5px}
.login-logo-sub{font-size:12px;color:var(--t3);margin-top:2px}
.login-form{width:100%;max-width:360px}
.login-form h2{font-size:22px;font-weight:700;margin-bottom:6px}
.login-form .sub{font-size:13px;color:var(--t3);margin-bottom:32px}
.lf-group{margin-bottom:16px}
.lf-label{font-size:12px;font-weight:600;color:var(--t2);margin-bottom:6px;display:block}
.lf-input{width:100%;height:42px;padding:0 14px;border:1px solid var(--bd);border-radius:8px;font-size:13.5px;font-family:'Noto Sans KR',sans-serif;outline:none;transition:border .15s,box-shadow .15s}
.lf-input:focus{border-color:var(--pr);box-shadow:0 0 0 3px rgba(43,92,230,.1)}
.lf-btn{width:100%;height:44px;background:var(--pr);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:700;font-family:'Noto Sans KR',sans-serif;cursor:pointer;margin-top:8px;transition:background .15s}
.lf-btn:hover{background:var(--pr-d)}
.lf-err{font-size:12px;color:var(--er);margin-top:8px;display:none}
.lf-err.show{display:block}
.login-right{width:50%;background-color:#fff;background-image:url('../../public/whatabread_main.png');background-size:contain;background-position:center 58%;background-repeat:no-repeat;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;padding:0;position:relative;overflow:hidden}
.login-right::before{display:none}
.login-brand{font-size:48px;font-weight:700;font-family:'DM Sans',sans-serif;letter-spacing:-2px;position:relative;z-index:1}
.login-brand-sub{font-size:18px;opacity:.8;margin-top:8px;position:relative;z-index:1;letter-spacing:1px}
.login-brand-desc{font-size:13px;opacity:.6;margin-top:20px;text-align:center;position:relative;z-index:1;line-height:1.8}
.login-deco{position:absolute;width:300px;height:300px;border:2px solid rgba(255,255,255,.1);border-radius:50%;bottom:-80px;right:-80px}
.login-deco2{position:absolute;width:200px;height:200px;border:2px solid rgba(255,255,255,.07);border-radius:50%;top:-50px;left:-50px}
.login-right .login-brand,.login-right .login-brand-sub,.login-right .login-brand-desc,.login-right .login-deco,.login-right .login-deco2{display:none}

/* ── APP SHELL ── */
.app{display:none;height:100vh;overflow:hidden}
.app.on{display:flex}

/* ── SIDEBAR ── */
.sidebar{width:var(--sw);background:var(--sf);border-right:1px solid var(--bd);display:flex;flex-direction:column;flex-shrink:0;z-index:var(--z-sidebar)}
.sidebar-backdrop{display:none}
.sidebar-logo{height:var(--hh);display:flex;align-items:center;padding:0 14px;border-bottom:1px solid var(--bd);gap:10px;flex-shrink:0;cursor:pointer}
.sidebar-logo:hover .logo-text{color:var(--pr)}
.logo-mark{width:30px;height:30px;border-radius:7px;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;background:#fff;border:1px solid var(--bd)}
.logo-mark img{width:100%;height:100%;object-fit:contain;display:block}
.logo-text{font-weight:700;font-size:13px;letter-spacing:-.3px;transition:color .15s}
.logo-sub{font-size:10px;color:var(--t3)}
.sidebar-nav{flex:1;padding:10px 8px;overflow-y:auto}

/* 단일 메뉴 (아코디언 없음) */
.nav-single{display:flex;align-items:center;gap:8px;padding:9px 10px;border-radius:7px;cursor:pointer;color:var(--t2);font-size:14px;font-weight:700;transition:all .12s;margin-bottom:2px}
.nav-single:hover{background:var(--sf2);color:var(--t1)}
.nav-single.active{background:var(--pr-l);color:var(--pr)}
.nav-single svg{flex-shrink:0;width:15px;height:15px}

/* 그룹 헤더 (대메뉴) */
.nav-group{margin-bottom:4px}
.nav-group-hdr{display:flex;align-items:center;justify-content:space-between;padding:8px 10px 5px;cursor:pointer;user-select:none;border-radius:6px;transition:background .12s}
.nav-group-hdr:hover{background:var(--sf2)}
.nav-group-name{font-size:13px;font-weight:700;color:var(--t1);letter-spacing:-.2px}
.nav-group-arrow{font-size:9px;color:var(--t3);transition:transform .2s}
.nav-group.collapsed .nav-group-arrow{transform:rotate(-90deg)}
.nav-group-items{overflow:hidden;transition:max-height .2s ease}
.nav-group.collapsed .nav-group-items{max-height:0!important}

.nav-item{display:flex;align-items:center;gap:8px;padding:6px 10px 6px 22px;border-radius:6px;cursor:pointer;color:var(--t2);font-size:12.5px;font-weight:500;transition:all .12s;margin-bottom:1px}
.nav-item:hover{background:var(--sf2);color:var(--t1)}
.nav-item.active{background:var(--pr-l);color:var(--pr);font-weight:600}
.nav-item svg{flex-shrink:0;width:13px;height:13px}

/* ── TOPBAR ── */
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}
.topbar{height:var(--hh);background:var(--sf);border-bottom:1px solid var(--bd);display:flex;align-items:center;padding:0 20px;gap:12px;flex-shrink:0}
.topbar-left{display:flex;align-items:center;gap:8px;flex:1;min-width:0}
.mobile-menu-btn{display:none;align-items:center;justify-content:center;width:34px;height:34px;border:1px solid var(--bd);border-radius:7px;background:#fff;color:var(--t2);cursor:pointer;flex-shrink:0;transition:background .12s,color .12s}
.mobile-menu-btn:hover{background:var(--sf2);color:var(--t1)}
.topbar-back{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;cursor:pointer;color:var(--t2);border:1px solid var(--bd);background:var(--sf);transition:all .12s;flex-shrink:0}
.topbar-back:hover{background:var(--sf2);color:var(--t1)}
.topbar-back.hidden{display:none}
.topbar-title{font-size:15px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topbar-right{display:flex;align-items:center;gap:16px;flex-shrink:0}
.topbar-userinfo{text-align:right;line-height:1.4}
.topbar-userinfo .tu-role{font-size:10px;color:var(--t3)}
.topbar-userinfo .tu-name{font-size:12.5px;font-weight:700;color:var(--t1)}
.topbar-userinfo .tu-date{font-size:10.5px;color:var(--t3)}
.topbar-icons{display:flex;align-items:center;gap:6px}
.topbar-icons .ic-btn{width:32px;height:32px;border-radius:7px;border:none;background:transparent;cursor:pointer;color:var(--t2);display:flex;align-items:center;justify-content:center;transition:all .12s;position:relative}
.topbar-icons .ic-btn:hover{background:var(--sf2);color:var(--t1)}
.notif-dot{position:absolute;top:5px;right:5px;width:7px;height:7px;background:var(--er);border-radius:50%;border:1.5px solid var(--sf)}

/* ── USER INFO DROPDOWN ── */
.user-dropdown{position:absolute;top:calc(var(--hh) + 4px);right:20px;background:var(--sf);border:1px solid var(--bd);border-radius:var(--rl);box-shadow:var(--shm);width:280px;z-index:var(--z-dropdown);display:none}
.user-dropdown.open{display:block}
.ud-header{padding:16px;border-bottom:1px solid var(--bd);display:flex;gap:12px;align-items:center}
.ud-avatar{width:46px;height:46px;border-radius:50%;background:var(--pr);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;flex-shrink:0}
.ud-info{flex:1}
.ud-name{font-size:14px;font-weight:700}
.ud-meta{font-size:11.5px;color:var(--t2);margin-top:2px}
.ud-body{padding:12px}
.ud-field{display:flex;justify-content:space-between;padding:5px 0;font-size:12px;border-bottom:1px solid var(--bdl)}
.ud-field:last-child{border-bottom:none}
.ud-field .lk{color:var(--t3)}
.ud-field .vl{font-weight:500;color:var(--t1)}

/* ── CONTENT ── */
.content{flex:1;overflow-y:auto;padding:20px}
.page{display:none}
.page.active{display:block}

/* ── PAGE HEADER ── */
.bc{display:flex;align-items:center;gap:4px;font-size:11.5px;color:var(--t3);margin-bottom:8px}
.bc .lnk{cursor:pointer;color:var(--t3)}.bc .lnk:hover{color:var(--pr);text-decoration:underline}
.bc .sep{color:var(--t3)}.bc .cur{color:var(--t2);font-weight:500}
.ph{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:16px}
.ph-title{font-size:18px;font-weight:700}
.ph-sub{font-size:12px;color:var(--t2);margin-top:2px}

/* ── CARD ── */
.card{background:var(--sf);border:1px solid var(--bd);border-radius:var(--rl);padding:16px;box-shadow:var(--sh)}
.card+.card{margin-top:0px}
.ch{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.ct{font-size:13px;font-weight:600}
.cs{font-size:11px;color:var(--t3);margin-top:2px}

/* ── SECTION TITLE ── */
.sec{font-size:11.5px;font-weight:700;color:var(--t2);padding-bottom:8px;border-bottom:1px solid var(--bd);margin-bottom:12px;letter-spacing:.3px;text-transform:uppercase;display:flex;align-items:center;gap:8px}
.sec-txt{flex:1}
.sec-btns{display:flex;gap:5px;align-items:center}

/* ── FILTER BAR ── */
.fbar{background:var(--sf);border:1px solid var(--bd);border-radius:var(--rl);padding:14px 16px;margin-bottom:12px;box-shadow:var(--sh)}
.frow{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:10px}
.frow-text{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.frow-btns{display:flex;justify-content:center;gap:8px}
.fitem{display:flex;flex-direction:column;gap:4px}
.flbl{font-size:11px;font-weight:600;color:var(--t2)}
.finput,.fsel{height:var(--control-h);min-height:var(--control-h);padding:0 var(--control-padding-x);border:1px solid var(--control-border);border-radius:var(--control-radius);font-size:var(--control-font-size);font-family:'Noto Sans KR',sans-serif;background:#fff;outline:none;transition:border .12s;width:100%;cursor:pointer;box-sizing:border-box}
.finput:focus,.fsel:focus{border-color:var(--pr)}
.finput[type=date]{cursor:pointer}
.ftext-lbl{font-size:12px;font-weight:600;color:var(--t2);white-space:nowrap}
.ftext-inp{flex:1;max-width:50%;height:var(--control-h);min-height:var(--control-h);padding:0 var(--control-padding-x);border:1px solid var(--control-border);border-radius:var(--control-radius);font-size:var(--control-font-size);font-family:'Noto Sans KR',sans-serif;background:#fff;outline:none;box-sizing:border-box}
.ftext-inp:focus{border-color:var(--pr)}
.frow-text{display:flex;flex-direction:column;align-items:stretch;gap:4px}
.ftext-lbl{font-size:11px}
.ftext-inp{max-width:none;width:100%}

.bom-search-cell{position:relative;min-width:240px}
.bom-search-popover{display:none;position:fixed;z-index:var(--z-popover);max-height:320px;overflow-y:auto;background:#fff;border:1px solid var(--bd);border-radius:10px;box-shadow:0 12px 30px rgba(15,23,42,.18)}
.bom-search-popover.open{display:block}
.bom-search-results{display:none}
.bom-search-input{height:var(--control-h);min-height:var(--control-h);box-sizing:border-box;padding:0 10px}
.bom-result{width:100%;min-height:42px;border:0;background:#fff;text-align:left;padding:8px 10px;border-bottom:1px solid var(--bd);cursor:pointer;font-family:'Noto Sans KR',sans-serif}
.bom-result:hover{background:var(--sf2)}
.bom-result-main{display:block;font-size:12px;font-weight:700;color:var(--t1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bom-result-sub{display:block;font-size:11px;color:var(--t3);margin-top:2px}
.bom-search-result-meta{display:flex;flex-wrap:wrap;gap:4px 8px;font-size:11px;color:var(--t3);margin-top:2px}
.bom-search-result-branches{display:block;font-size:11px;color:var(--t2);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bom-search-result-branches strong{color:var(--t3);font-weight:600}
.bom-search-empty{padding:9px 10px;font-size:11.5px;color:var(--t3)}
.product-bom-table-wrap{overflow-x:auto}
.product-bom-table{min-width:920px}
.product-bom-baker-percent{font-weight:700;color:var(--t1);white-space:nowrap}
.bom-total-bar{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px 18px;padding:8px;font-size:12.5px}
.bom-total-bar span{white-space:nowrap;color:var(--t2)}
.bom-total-bar strong{color:var(--t1)}
.access-denied-card{padding:32px 16px}
.fixture-product-field{min-width:280px}
.fixture-product-search-box{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:6px;align-items:center}
.fixture-product-search-input{height:var(--control-h);min-height:var(--control-h);box-sizing:border-box}
.fixture-selected-product{margin-top:6px;padding:8px 10px;border:1px dashed var(--bd);border-radius:8px;background:var(--sf2);font-size:11.5px;color:var(--t3);line-height:1.45}
.fixture-selected-product.has-product{border-style:solid;background:#fff;color:var(--t2)}
.fixture-selected-title{font-size:12px;font-weight:700;color:var(--t1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fixture-selected-meta{margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fixture-product-search-popover,.product-search-popover{display:none;position:fixed;z-index:var(--z-popover);max-height:360px;overflow-y:auto;background:#fff;border:1px solid var(--bd);border-radius:10px;box-shadow:0 12px 30px rgba(15,23,42,.18)}
.fixture-product-search-popover.open,.product-search-popover.open{display:block}
.fixture-product-search-result-item,.product-search-result-item{width:100%;min-height:54px;border:0;background:#fff;text-align:left;padding:9px 10px;border-bottom:1px solid var(--bd);cursor:pointer;font-family:'Noto Sans KR',sans-serif}
.fixture-product-search-result-item:hover,.product-search-result-item:hover{background:var(--sf2)}
.fixture-product-result-main{display:block;font-size:12px;font-weight:700;color:var(--t1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fixture-product-result-meta{display:flex;flex-wrap:wrap;gap:4px 8px;font-size:11px;color:var(--t3);margin-top:2px}
.fixture-product-result-branches{display:block;font-size:11px;color:var(--t2);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.fixture-product-result-branches strong{color:var(--t3);font-weight:600}
.fixture-product-search-empty{padding:10px;font-size:11.5px;color:var(--t3)}

/* ── TABLE ── */
.tw{overflow-x:auto}
table{width:100%;border-collapse:collapse;border:1px solid var(--bd)}
th{text-align:center;padding:8px 10px;font-size:11px;font-weight:600;color:var(--t2);background:var(--sf2);border:1px solid var(--bd);white-space:nowrap}
td{padding:9px 10px;font-size:12px;border:1px solid var(--bd);text-align:center;vertical-align:middle}
td.tl{text-align:left}
tbody tr.cr{cursor:pointer;transition:background .1s}
tbody tr.cr:hover td{background:#F5F7FF}
.product-branches-cell{max-width:180px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--t2);font-size:12px}

/* ── BADGE ── */
.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:500;white-space:nowrap}
.bb{background:var(--pr-l);color:var(--pr)}.bg{background:var(--okl);color:var(--ok)}.by{background:var(--wal);color:#92400E}.br{background:var(--erl);color:var(--er)}.bgr{background:var(--sf2);color:var(--t2)}
.b-draft{background:#F3F4F6;color:#374151;border:1px solid #E5E7EB}.b-sub{background:var(--okl);color:#065F46;border:1px solid #A7F3D0}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;border-radius:6px;border:none;font-size:12.5px;font-weight:600;cursor:pointer;font-family:'Noto Sans KR',sans-serif;transition:all .13s;white-space:nowrap}
.btn-pr{background:var(--pr);color:#fff}.btn-pr:hover{background:var(--pr-d)}
.btn-ol{background:#fff;color:var(--t1);border:1px solid var(--bd)}.btn-ol:hover{background:var(--sf2)}
.btn-er{background:var(--er);color:#fff}.btn-er:hover{background:#DC2626}
.btn-ok{background:var(--ok);color:#fff}
.btn-wa{background:var(--wa);color:#fff}
.btn-add{background:var(--pr-l);color:var(--pr);border:1px solid var(--pr-l)}.btn-add:hover{background:var(--pr);color:#fff}
.btn-dl{background:#374151;color:#fff;font-weight:700}.btn-dl:hover{background:#111827}
.btn-sm{padding:5px 11px;font-size:11.5px}
.btn-xs{padding:3px 8px;font-size:11px}
.btn:disabled{opacity:.45;cursor:not-allowed}
.btn-x{width:22px;height:22px;border-radius:4px;border:1px solid var(--bd);background:var(--sf2);cursor:pointer;font-size:11px;display:inline-flex;align-items:center;justify-content:center;color:var(--t2);flex-shrink:0;transition:all .12s}
.btn-x:hover{background:var(--erl);border-color:var(--er);color:var(--er)}

/* ── FORM ── */
.fg{display:grid;gap:12px;margin-bottom:12px}
.fg2{grid-template-columns:repeat(2,1fr)}.fg3{grid-template-columns:repeat(3,1fr)}.fg4{grid-template-columns:repeat(4,1fr)}.fg5{grid-template-columns:repeat(5,1fr)}
.sp2{grid-column:span 2}.sp3{grid-column:span 3}.sp4{grid-column:span 4}
.fgrp{display:flex;flex-direction:column;gap:5px}
.lbl{font-size:11.5px;font-weight:600;color:var(--t2)}
.lbl .req{color:var(--pr);margin-left:2px}
.inp,.sel,.ta{font-family:'Noto Sans KR',sans-serif;font-size:var(--control-font-size);border:1px solid var(--control-border);border-radius:var(--control-radius);color:var(--t1);outline:none;background:#fff;transition:border .12s,box-shadow .12s;width:100%}
.inp{height:var(--control-h);min-height:var(--control-h);padding:0 var(--control-padding-x)}.sel{height:var(--control-h);min-height:var(--control-h);padding:0 var(--control-padding-x);cursor:pointer}.ta{padding:8px 10px;min-height:72px;resize:vertical}
.inp:focus,.sel:focus,.ta:focus{border-color:var(--pr);box-shadow:0 0 0 3px rgba(43,92,230,.08)}
.inp[readonly],.inp[disabled],.sel[disabled],.ta[disabled]{background:var(--sf2);cursor:default;color:var(--t2)}
.tenant-settings-card{margin-bottom:12px}
.tenant-settings-fields{align-items:end}
.tenant-image-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.tenant-image-box{border:1px solid var(--bd);border-radius:8px;padding:12px;background:#fff;min-width:0}
.tenant-preview{height:120px;border:1px dashed var(--bd);border-radius:8px;background:var(--sf2);display:flex;align-items:center;justify-content:center;overflow:hidden;margin:8px 0}
.tenant-preview img{max-width:100%;max-height:100%;object-fit:contain;display:block}
.tenant-preview-main{height:160px}
.tenant-preview-main img{width:100%;height:100%;object-fit:contain}
.tenant-preview-favicon{height:88px}
.tenant-preview-favicon img{width:48px;height:48px;object-fit:contain}
.tenant-upload-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:center}
.tenant-upload-row input[type=file]{padding-top:7px}
.filter-field input:not([type="checkbox"]):not([type="radio"]),
.filter-field select,
.frow input:not([type="checkbox"]):not([type="radio"]),
.frow select,
.ftext-inp,
.search-input,
.bom-search-input,
input:not(.lf-input)[type="text"],
input:not(.lf-input)[type="search"],
input:not(.lf-input)[type="date"],
input:not(.lf-input)[type="number"],
input:not(.lf-input)[type="password"],
input:not(.lf-input)[type="email"],
select{
  height:var(--control-h);
  min-height:var(--control-h);
  box-sizing:border-box;
  padding:0 var(--control-padding-x);
  border-radius:var(--control-radius);
  font-size:var(--control-font-size);
  line-height:normal;
}
.inp-hint{font-size:10.5px;color:var(--t3);margin-top:3px}
.inp-err{font-size:10.5px;color:var(--er);margin-top:2px;display:none}
.inp-err.show{display:block}
.inp-ok{font-size:10.5px;color:var(--ok);margin-top:2px;display:none}
.inp-ok.show{display:block}
.pw-wrap{position:relative}
.pw-wrap .inp{padding-right:36px}

/* 구분+내용 행 */
.cat-row{display:flex;gap:6px;margin-bottom:6px;align-items:stretch}
.cat-row .cat-type{width:10%;min-width:80px;flex-shrink:0}
.cat-row .cat-body{flex:1}
.cat-row .cat-del{flex-shrink:0;align-self:center}
.cat-row input,.cat-row textarea{height:34px;padding:0 8px;border:1px solid var(--bd);border-radius:5px;font-size:12px;font-family:'Noto Sans KR',sans-serif;outline:none;width:100%}
.cat-row input:focus,.cat-row textarea:focus{border-color:var(--pr)}

/* 순번 행 */
.seq-row{display:flex;gap:6px;margin-bottom:6px;align-items:center}
.seq-num{width:32px;text-align:center;font-size:12px;font-weight:700;color:var(--t3);flex-shrink:0}
.seq-inp{flex:1;height:32px;padding:0 8px;border:1px solid var(--bd);border-radius:5px;font-size:12px;font-family:'Noto Sans KR',sans-serif;outline:none}
.seq-inp:focus{border-color:var(--pr)}

/* 체크리스트 */
.chk-row{display:flex;align-items:center;gap:8px;padding:7px 0;border-bottom:1px solid var(--bdl)}
.chk-row:last-child{border-bottom:none}
.chk-box{width:16px;height:16px;border:2px solid var(--bd);border-radius:3px;flex-shrink:0;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .12s}
.chk-box.on{background:var(--pr);border-color:var(--pr)}
.chk-box.on::after{content:'✓';color:#fff;font-size:10px;font-weight:700}
.chk-inp{flex:1;height:30px;padding:0 8px;border:1px solid var(--bd);border-radius:5px;font-size:12.5px;font-family:'Noto Sans KR',sans-serif;outline:none}
.chk-inp:focus{border-color:var(--pr)}

/* 멤버 태그 */
.member-tags{display:flex;flex-wrap:wrap;gap:6px;min-height:28px;padding:6px 0}
.mtag{display:inline-flex;align-items:center;gap:4px;background:var(--pr-l);color:var(--pr);padding:3px 8px;border-radius:20px;font-size:11.5px;font-weight:500;cursor:default}
.mtag .rm{cursor:pointer;font-size:11px;color:var(--pr);opacity:.7}.mtag .rm:hover{opacity:1}

/* 평가 행 */
.eval-row{display:flex;gap:8px;margin-bottom:8px;align-items:flex-start;padding:8px;background:var(--sf2);border-radius:6px;border:1px solid var(--bd)}
.eval-who{width:100px;flex-shrink:0}
.eval-who .who-name{font-size:12.5px;font-weight:600;color:var(--t1)}
.eval-who .who-role{font-size:11px;color:var(--t3)}
.eval-fields{flex:1;display:flex;gap:6px}
.eval-type{width:10%;min-width:70px}
.eval-type input{height:30px;padding:0 6px;border:1px solid var(--bd);border-radius:5px;font-size:12px;width:100%;font-family:'Noto Sans KR',sans-serif;outline:none}
.eval-type input:focus{border-color:var(--pr)}
.eval-content{flex:1}
.eval-content input{height:30px;padding:0 8px;border:1px solid var(--bd);border-radius:5px;font-size:12px;width:100%;font-family:'Noto Sans KR',sans-serif;outline:none}
.eval-content input:focus{border-color:var(--pr)}

/* 이미지 첨부 */
.img-wrap{display:flex;flex-wrap:wrap;gap:10px}
.img-wrap.drop-ready{border:1px dashed var(--bd);border-radius:8px;padding:10px;transition:background .12s,border-color .12s}
.img-wrap.drag-over{border-color:var(--pr);background:var(--pr-l)}
.img-add-btn{width:90px;height:72px;border:2px dashed var(--bd);border-radius:var(--r);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:3px;cursor:pointer;color:var(--t3);font-size:11px;transition:all .12s}
.img-add-btn:hover{border-color:var(--pr);color:var(--pr)}
.img-thumb{position:relative;display:inline-flex;flex-direction:column;gap:4px;width:90px}
.img-thumb img{width:90px;height:72px;border-radius:var(--r);object-fit:cover;border:1px solid var(--bd);cursor:pointer}
.img-thumb .rm{position:absolute;top:3px;right:3px;width:18px;height:18px;border-radius:50%;background:rgba(0,0,0,.55);color:#fff;border:none;cursor:pointer;font-size:10px;display:flex;align-items:center;justify-content:center}
.file-download-btn{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:rgba(0,0,0,.55);color:#fff;border:none;cursor:pointer;font-size:12px;display:flex;align-items:center;justify-content:center;line-height:1}
.file-name{font-size:10.5px;color:var(--t3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center;max-width:90px}

/* 이미지 뷰어 */
.imgv-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:var(--z-viewer);align-items:center;justify-content:center}
.imgv-overlay.open{display:flex}
.imgv-box{position:relative;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center}
.imgv-box img{max-width:100%;max-height:80vh;border-radius:8px;object-fit:contain}
.imgv-controls{display:flex;gap:10px;margin-top:12px}
.imgv-btn{padding:8px 18px;border-radius:6px;border:none;cursor:pointer;font-size:12.5px;font-weight:600;font-family:'Noto Sans KR',sans-serif}
.imgv-close{position:absolute;top:-12px;right:-12px;width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.15);border:none;color:#fff;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center}
.imgv-close:hover{background:rgba(255,255,255,.3)}

/* 생산 테이블 */
.ptbl th{font-size:10px;padding:5px 6px}
.ptbl td{padding:4px 6px;font-size:11.5px}
.ptbl input{height:24px;padding:0 4px;border:1px solid var(--bd);border-radius:3px;font-size:11px;text-align:right;width:54px;outline:none;font-family:'DM Sans',sans-serif}
.ptbl input:focus{border-color:var(--pr)}
.ptbl input.d{border-color:#FECACA;background:#FFF5F5}
.ptbl tfoot td{font-weight:700;background:var(--sf2);font-size:11.5px}
.ptbl .sale-cell{background:#1F2937;color:#1F2937;cursor:not-allowed;user-select:none;position:relative}
.ptbl .sale-cell input{background:#374151;color:#374151;border-color:#4B5563;cursor:not-allowed;pointer-events:none}
.sale-blocked{background:#374151;color:#374151;cursor:not-allowed;position:relative}
.prod-entry-table-wrap{display:block}
.prod-entry-card-list{display:none}
.prod-entry-mobile-search{display:none}
.prod-entry-mobile-savebar{display:none}
.prod-entry-card{background:#fff;border:1px solid var(--bd);border-radius:10px;padding:12px;box-shadow:var(--sh)}
.prod-entry-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.prod-entry-name{font-weight:700;font-size:14px;color:var(--t1);word-break:break-word}
.prod-entry-meta{margin-top:2px;font-size:11px;color:var(--t3)}
.prod-entry-inputs{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px}
.prod-entry-inputs label span{display:block;font-size:11px;font-weight:600;color:var(--t2);margin-bottom:4px}
.prod-entry-inputs input{width:100%;height:38px;padding:0 10px;border:1px solid var(--bd);border-radius:6px;font-size:14px;text-align:right;font-family:'Noto Sans KR',sans-serif;outline:none;background:#fff}
.prod-entry-inputs input:focus{border-color:var(--pr);box-shadow:0 0 0 3px rgba(43,92,230,.08)}
.prod-entry-mobile-save{display:none;margin-top:10px}
.prod-entry-compact-card{background:#fff;border:1px solid var(--bd);border-radius:8px;padding:8px 10px;box-shadow:var(--sh)}
.prod-entry-compact-card.has-value{border-color:var(--pr);background:#F8FAFF}
.prod-entry-compact-head{display:flex;justify-content:space-between;gap:8px;align-items:center;margin-bottom:6px}
.prod-entry-compact-name{font-weight:700;font-size:13px;color:var(--t1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.prod-entry-compact-meta{font-size:10.5px;color:var(--t3);white-space:nowrap;flex-shrink:0}
.prod-entry-compact-inputs{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.prod-entry-compact-field{display:flex;flex-direction:column;gap:4px;min-width:0}
.prod-entry-compact-field span{font-size:11px;color:var(--t2);white-space:nowrap}
.prod-entry-compact-field input{width:100%;min-width:0;height:36px;box-sizing:border-box;padding:0 8px;border:1px solid var(--bd);border-radius:6px;text-align:right;font-size:14px;font-family:'DM Sans',sans-serif;outline:none;background:#fff}
.prod-entry-compact-field input:focus{border-color:var(--pr);box-shadow:0 0 0 3px rgba(43,92,230,.08)}
.prod-entry-compact-field input.is-zero{color:var(--t3);background:#FAFAFB}
.prod-entry-mobile-savebar .count{flex:1;font-size:12px;color:var(--t2);font-weight:600}
.prod-entry-mobile-savebar .btn{flex-shrink:0}

/* 모달 */
.mo{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:var(--z-modal);align-items:center;justify-content:center}
.mo.open{display:flex}
.mo-box{background:var(--sf);border-radius:var(--rl);box-shadow:var(--shm);width:580px;max-width:95vw;max-height:82vh;display:flex;flex-direction:column}
.mo-hdr{padding:15px 20px;border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.mo-title{font-size:15px;font-weight:700}
.mo-close{width:28px;height:28px;border:none;background:transparent;cursor:pointer;border-radius:5px;display:flex;align-items:center;justify-content:center;color:var(--t2);font-size:18px}
.mo-close:hover{background:var(--sf2)}
.mo-body{padding:16px 20px;overflow-y:auto;flex:1}
.mo-foot{padding:12px 20px;border-top:1px solid var(--bd);display:flex;justify-content:flex-end;gap:8px;flex-shrink:0}

/* 확인 팝업 */
.conf{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:var(--z-modal);align-items:center;justify-content:center}
.conf.open{display:flex}
.conf-box{background:var(--sf);border-radius:var(--rl);box-shadow:var(--shm);padding:28px;width:380px;text-align:center}
.conf-icon{font-size:36px;margin-bottom:12px}
.conf-msg{font-size:13.5px;line-height:1.7;margin-bottom:20px}
.conf-btns{display:flex;gap:10px;justify-content:center}

/* 토스트 (중앙) */
.toast{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(.9);background:rgba(17,24,39,.92);color:#fff;padding:14px 28px;border-radius:10px;font-size:14px;font-weight:600;box-shadow:var(--shm);z-index:var(--z-toast);opacity:0;transition:all .25s;pointer-events:none;text-align:center;white-space:pre-line;max-width:380px}
.toast.show{opacity:1;transform:translate(-50%,-50%) scale(1)}

.product-bulk-upload-modal{width:720px}
.bulk-upload-result{display:flex;flex-direction:column;gap:12px}
.bulk-upload-summary{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
.bulk-upload-summary>div{border:1px solid var(--bd);border-radius:8px;background:#fff;padding:14px 12px;display:flex;flex-direction:column;gap:4px;align-items:center;justify-content:center}
.bulk-upload-count{font-size:22px;font-weight:800;color:var(--pr);line-height:1}
.bulk-upload-summary span:last-child{font-size:12px;color:var(--t2);font-weight:700}
.bulk-upload-error-head{font-size:12.5px;font-weight:700;color:var(--t1);background:#FFF7ED;border:1px solid #FED7AA;border-radius:8px;padding:10px 12px}
.bulk-upload-error-list{border:1px solid var(--bd);border-radius:8px;background:#fff;max-height:420px;overflow-y:auto}
.bulk-upload-error-item{display:grid;grid-template-columns:74px 150px minmax(0,1fr);gap:10px;align-items:start;padding:10px 12px;border-bottom:1px solid var(--bdl);font-size:12px}
.bulk-upload-error-item:last-child{border-bottom:none}
.bulk-upload-row{font-weight:800;color:#B91C1C}
.bulk-upload-field{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;color:var(--t2);word-break:break-all}
.bulk-upload-message{color:var(--t1);line-height:1.45}

/* 알림 드롭다운 */
.notif-drop{position:absolute;top:calc(var(--hh) + 4px);right:60px;background:var(--sf);border:1px solid var(--bd);border-radius:var(--rl);box-shadow:var(--shm);width:320px;z-index:var(--z-dropdown);display:none}
.notif-drop.open{display:block}
.nd-hdr{padding:12px 16px;border-bottom:1px solid var(--bd);font-size:13px;font-weight:700}
.nd-hdr{display:flex;align-items:center;justify-content:space-between;gap:8px}
.nd-read-all{border:none;background:transparent;color:var(--pr);font-size:11px;font-weight:700;cursor:pointer;font-family:'Noto Sans KR',sans-serif}
.nd-list{max-height:360px;overflow-y:auto}
.nd-item{padding:10px 16px;border-bottom:1px solid var(--bdl);cursor:pointer;font-size:12.5px}
.nd-item.unread{background:#F5F8FF}
.nd-item:hover{background:var(--sf2)}
.nd-item:last-child{border-bottom:none}
.nd-title{font-size:12.5px;font-weight:700;color:var(--t1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.nd-msg{font-size:11.5px;color:var(--t2);margin-top:2px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.nd-badge{font-size:10px;color:var(--t3);margin-top:2px}

/* 로그아웃 드롭다운 */
.lo-drop{position:absolute;top:calc(var(--hh) + 4px);right:16px;background:var(--sf);border:1px solid var(--bd);border-radius:var(--rl);box-shadow:var(--shm);width:160px;z-index:var(--z-dropdown);display:none}
.lo-drop.open{display:block}
.lo-item{padding:10px 16px;cursor:pointer;font-size:12.5px;display:flex;align-items:center;gap:8px;border-radius:var(--rl)}
.lo-item:hover{background:var(--sf2)}
.lo-item.danger{color:var(--er)}

/* 페이지네이션 */
.pgn{display:flex;align-items:center;justify-content:space-between;padding-top:12px;margin-top:4px}
.pgn-info{font-size:11.5px;color:var(--t3)}
.pgn-btns{display:flex;gap:3px}
.pg-btn{min-width:28px;height:28px;border-radius:5px;border:1px solid var(--bd);background:#fff;font-size:12px;cursor:pointer;color:var(--t2);display:flex;align-items:center;justify-content:center;padding:0 6px}
.pg-btn.on{background:var(--pr);color:#fff;border-color:var(--pr);font-weight:600}
.pg-btn:hover:not(.on){background:var(--sf2)}
.pager{display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-wrap:wrap;width:100%}
.pager-info{font-size:11.5px;color:var(--t3);margin-right:auto;white-space:nowrap}
.pager-buttons{display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.pager-btn{min-width:30px;height:30px;border-radius:5px;border:1px solid var(--bd);background:#fff;font-size:12px;cursor:pointer;color:var(--t2);display:flex;align-items:center;justify-content:center;padding:0 8px;font-family:'Noto Sans KR',sans-serif}
.pager-btn.active{background:var(--pr);color:#fff;border-color:var(--pr);font-weight:700}
.pager-btn:hover:not(.active):not(:disabled){background:var(--sf2)}
.pager-btn:disabled{opacity:.45;cursor:not-allowed}
.pager-ellipsis{height:30px;display:flex;align-items:center;color:var(--t3);font-size:12px;padding:0 2px}
.pager-size{height:30px;display:flex;align-items:center;gap:5px;font-size:11.5px;color:var(--t3);white-space:nowrap}
.pager-size select{height:30px;border:1px solid var(--bd);border-radius:5px;background:#fff;color:var(--t2);font-size:12px;padding:0 24px 0 8px;font-family:'Noto Sans KR',sans-serif}

.perm-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px;flex-wrap:wrap}
.perm-role-tabs{display:flex;gap:6px;flex-wrap:wrap}
.perm-role-tab{height:30px;padding:0 14px;border:1px solid var(--bd);background:#fff;border-radius:6px;cursor:pointer;font-size:12px;font-weight:700;color:var(--t2);font-family:'Noto Sans KR',sans-serif}
.perm-role-tab.on{background:var(--pr);border-color:var(--pr);color:#fff}
.perm-note{font-size:11.5px;color:var(--t3)}
.perm-code{font-size:10.5px;color:var(--t3);margin-top:2px}
.perm-table input[type="checkbox"]{width:16px;height:16px;cursor:pointer}
.perm-table input[type="checkbox"]:disabled{cursor:not-allowed}
.permission-tabs{display:inline-flex;align-items:center;gap:4px;padding:4px;background:var(--sf);border:1px solid var(--bd);border-radius:10px;margin-bottom:12px}
.permission-tab{height:34px;padding:0 14px;border:0;border-radius:8px;background:transparent;color:var(--t2);font-size:13px;font-weight:700;cursor:pointer;font-family:'Noto Sans KR',sans-serif;transition:color .12s,background .12s,box-shadow .12s}
.permission-tab.active{background:#fff;color:var(--pr);box-shadow:0 1px 4px rgba(15,23,42,.12)}
.permission-tab:hover{color:var(--pr)}

/* 대시보드 차트 */
.chart-area{height:100px;display:flex;align-items:flex-end;gap:4px;padding:0 4px}
.chart-grp{flex:1;display:flex;align-items:flex-end;gap:2px}
.bar-prod{flex:1;border-radius:3px 3px 0 0;background:#93C5FD;cursor:pointer;transition:background .15s;min-width:6px}
.bar-prod:hover{background:var(--pr)}
.bar-disc{flex:1;border-radius:3px 3px 0 0;background:#FCA5A5;cursor:pointer;transition:background .15s;min-width:6px}
.bar-disc:hover{background:var(--er)}
.chart-lbl{font-size:9px;color:var(--t3);text-align:center;margin-top:3px;white-space:nowrap}
.chart-tabs{display:flex;gap:4px}
.ctab{padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;cursor:pointer;border:1px solid var(--bd);background:#fff;color:var(--t2);transition:all .12s}
.ctab.on{background:var(--pr);color:#fff;border-color:var(--pr)}
.chart-legend{display:flex;gap:12px;font-size:11px;color:var(--t2);margin-top:6px}
.leg-dot{width:10px;height:10px;border-radius:2px;display:inline-block;margin-right:3px}
.dashboard-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:12px}
.dashboard-main-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:12px;align-items:start}
.dashboard-card-stack{display:flex;flex-direction:column;gap:12px}
.dashboard-widget.is-hidden,.dashboard-summary-grid.is-hidden,.dashboard-main-grid.is-hidden,.dashboard-card-stack.is-hidden{display:none!important}
.dashboard-prod-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}
.dashboard-prod-metric{border:1px solid var(--bd);border-radius:var(--rl);padding:10px;background:var(--sf2)}
.dashboard-prod-metric .lbl{font-size:11px;color:var(--t3);margin-bottom:4px}
.dashboard-prod-metric .val{font-size:18px;font-weight:700;font-family:'DM Sans',sans-serif}
.dashboard-branch-list{display:flex;flex-direction:column;gap:8px}
.dashboard-branch-row{border:1px solid var(--bd);border-radius:var(--rl);padding:9px 10px;background:#fff}
.dashboard-branch-head{display:flex;align-items:center;justify-content:space-between;font-size:12px;font-weight:600;margin-bottom:6px}
.dashboard-branch-meta{font-size:11px;color:var(--t3);display:flex;gap:10px;flex-wrap:wrap}
.dashboard-list{display:flex;flex-direction:column;gap:8px}
.dashboard-list-item{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--bdl);border-radius:8px;background:#fff;cursor:pointer;transition:background .12s,border-color .12s}
.dashboard-list-item:hover{background:var(--sf2);border-color:var(--bd)}
.dashboard-list-main{min-width:0}
.dashboard-list-title{font-size:12.5px;font-weight:700;color:var(--t1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dashboard-list-meta{font-size:11px;color:var(--t3);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dashboard-list-side{text-align:right;white-space:nowrap}
.dashboard-list-date{font-size:11px;color:var(--t3);margin-bottom:3px}
.dashboard-empty{padding:18px;text-align:center;color:var(--t3);border:1px dashed var(--bd);border-radius:8px;background:var(--sf)}
.dashboard-empty-full{padding:32px;text-align:center;color:var(--t3);border:1px dashed var(--bd);border-radius:12px;background:#fff}
.dashboard-empty-full.hidden,.dashboard-empty-full.is-hidden{display:none!important}
.dashboard-type-badge{display:inline-flex;align-items:center;padding:3px 8px;border-radius:20px;font-size:11px;font-weight:700;white-space:nowrap}
.dashboard-type-badge.bb{background:#DBEAFE;color:#1D4ED8}.dashboard-type-badge.bg{background:#D1FAE5;color:#047857}.dashboard-type-badge.by{background:#FEF3C7;color:#92400E}.dashboard-type-badge.br{background:#FEE2E2;color:#B91C1C}.dashboard-type-badge.bgr{background:#F3F4F6;color:#4B5563}
.dashboard-schedule-badge{display:inline-flex;align-items:center;width:max-content;margin-bottom:4px;padding:2px 7px;border-radius:20px;background:rgba(255,255,255,.72);font-size:10.5px;font-weight:700;color:var(--t2)}
.guide-box{width:1040px;max-width:calc(100vw - 24px);max-height:86vh}
.guide-body{padding:0;overflow:hidden}
.guide-intro{padding:16px 18px;border-bottom:1px solid var(--bd);background:var(--sf2)}
.guide-lead{font-size:13px;color:var(--t2);line-height:1.6}
.guide-layout{display:grid;grid-template-columns:210px minmax(0,1fr);min-height:0}
.guide-nav{border-right:1px solid var(--bd);background:#fff;padding:10px;overflow-y:auto;max-height:calc(86vh - 132px)}
.guide-nav-item{width:100%;border:none;background:transparent;border-radius:7px;padding:8px 9px;text-align:left;font-family:'Noto Sans KR',sans-serif;font-size:12px;color:var(--t2);cursor:pointer}
.guide-nav-item:hover{background:var(--sf2);color:var(--t1)}
.guide-nav-item.active{background:var(--pr-l);color:var(--pr);font-weight:800}
.guide-content{padding:14px 16px 18px;overflow-y:auto;max-height:calc(86vh - 132px);scroll-behavior:smooth}
.guide-section{scroll-margin-top:12px;margin-bottom:22px}
.guide-section-title{font-size:16px;font-weight:900;color:var(--t1);margin-bottom:10px}
.guide-card{border:1px solid var(--bdl);border-radius:8px;padding:13px;background:#fff;margin-bottom:10px}
.guide-card-title{font-size:13px;font-weight:800;color:var(--t1);margin-bottom:7px}
.guide-step-list,.guide-list{margin:0;padding-left:18px;color:var(--t2);font-size:12.5px;line-height:1.7}
.guide-step-list li,.guide-list li{margin:2px 0}
.guide-field-list{margin:0;padding-left:18px;color:var(--t2);font-size:12.5px;line-height:1.7}
.guide-route{display:flex;gap:6px;align-items:center;flex-wrap:wrap;color:var(--t2);font-size:12.5px;line-height:1.7}
.guide-chip{display:inline-flex;align-items:center;border:1px solid var(--bd);border-radius:6px;background:var(--sf2);padding:2px 7px;font-size:11.5px;font-weight:800;color:var(--t1)}
.guide-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.guide-actions .btn{white-space:nowrap}
.guide-note,.guide-warning{border-radius:8px;padding:10px 12px;font-size:12px;line-height:1.6;margin-top:8px}
.guide-note{background:var(--pr-l);color:var(--pr);border:1px solid rgba(43,92,230,.16)}
.guide-warning{background:#FFF7ED;color:#9A3412;border:1px solid #FED7AA}
.guide-badges{display:flex;gap:6px;flex-wrap:wrap;margin:4px 0 8px}
.guide-badge{display:inline-flex;align-items:center;padding:3px 8px;border-radius:20px;background:var(--sf2);border:1px solid var(--bd);font-size:11px;font-weight:800;color:var(--t2)}

/* 대시보드 최근 활동 */
.act-table{width:100%;border-collapse:collapse;border:1px solid var(--bd)}
.act-table th,.act-table td{padding:8px 10px;text-align:left;font-size:12px;border:1px solid var(--bd)}
.act-table th{background:var(--sf2);font-weight:600;color:var(--t2);font-size:11px}
.act-table tbody{display:block;max-height:380px;overflow-y:auto}
.act-table thead,.act-table tbody tr{display:table;width:100%;table-layout:fixed}

/* 집기 현황 */
.fixture-stat{overflow-x:auto}
.fixture-stat table th,.fixture-stat table td{padding:7px 10px;font-size:12px}

/* misc */
.divider{height:1px;background:var(--bd);margin:14px 0}
.flex{display:flex}.ic{align-items:center}.jb{justify-content:space-between}
.g6{gap:6px}.g8{gap:8px}.g10{gap:10px}.g12{gap:12px}
.mt8{margin-top:8px}.mt12{margin-top:12px}.mt16{margin-top:16px}
.mb8{margin-bottom:8px}.mb12{margin-bottom:12px}.mb16{margin-bottom:16px}
.w100{width:100%}
.fw6{font-weight:600}.fw7{font-weight:700}
.cp{color:var(--pr)}.cm{color:var(--t3)}.cer{color:var(--er)}
.num{font-family:'DM Sans',sans-serif}
.g2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.stat-card{background:var(--sf);border:1px solid var(--bd);border-radius:var(--rl);padding:14px 16px;box-shadow:var(--sh)}
.stat-icon{width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:10px}
.si-b{background:var(--pr-l);color:var(--pr)}.si-g{background:var(--okl);color:var(--ok)}.si-y{background:var(--wal);color:var(--wa)}.si-r{background:var(--erl);color:var(--er)}
.stat-lbl{font-size:11px;color:var(--t3);font-weight:500;margin-bottom:5px}
.stat-val{font-size:22px;font-weight:700;font-family:'DM Sans',sans-serif}
.stat-note{font-size:11px;color:var(--t3);margin-top:3px}
.stat-note.up{color:var(--ok)}.stat-note.dn{color:var(--er)}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:#D1D5DB;border-radius:99px}
.form-frozen .inp,.form-frozen .sel,.form-frozen .ta,.form-frozen .chk-inp,.form-frozen .cat-row input,.form-frozen .cat-row textarea,.form-frozen .seq-inp,.form-frozen .eval-type input,.form-frozen .eval-content input{background:var(--sf2)!important;pointer-events:none;color:var(--t2)}
.form-frozen .chk-box{pointer-events:none;opacity:.6}
.form-frozen .btn-add,.form-frozen .btn-x{display:none!important}

/* 부서/직급 테이블 */
.dept-tbl{border:1px solid var(--bd);border-radius:8px;overflow:hidden}
.dept-tbl table{border:none}
.dept-tbl table th,.dept-tbl table td{border-color:var(--bdl)}
.dept-tbl .hdr{background:var(--sf2);padding:10px 14px;border-bottom:1px solid var(--bd);display:flex;align-items:center;justify-content:space-between}
.dept-tbl .hdr-title{font-size:13px;font-weight:700}

/* 캘린더 메모 */
.cal-toolbar,.calendar-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}
.cal-nav{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.cal-title{font-size:20px;font-weight:800;min-width:130px;text-align:center}
.calendar-year-select,.calendar-month-select{height:32px;padding:0 28px 0 10px;border:1px solid var(--bd);border-radius:6px;background:#fff;color:var(--t1);font-size:12.5px;font-weight:700;font-family:'Noto Sans KR',sans-serif;outline:none;cursor:pointer}
.calendar-year-select:focus,.calendar-month-select:focus{border-color:var(--pr);box-shadow:0 0 0 3px rgba(43,92,230,.08)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);border:1px solid var(--bd);border-radius:8px;overflow:hidden;background:var(--sf)}
.cal-dow{background:var(--sf2);padding:9px 6px;text-align:center;font-size:11.5px;font-weight:700;color:var(--t2);border-right:1px solid var(--bd)}
.cal-dow:last-child{border-right:none}
.cal-cell{min-height:118px;padding:8px;border-top:1px solid var(--bd);border-right:1px solid var(--bd);background:#fff;cursor:pointer;transition:background .12s}
.cal-cell:nth-child(7n){border-right:none}
.cal-cell:hover{background:#F8FAFF}
.cal-cell.muted,.cal-cell.cal-other-month{background:#FAFAFB;color:var(--t3)}
.cal-day{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;font-size:12px;font-weight:700}
.cal-sun{color:#DC2626}
.cal-sat{color:#2563EB}
.cal-other-month .cal-sun{color:#FCA5A5}
.cal-other-month .cal-sat{color:#93C5FD}
.cal-day.today span,.cal-day.cal-today span{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:var(--pr);color:#fff}
.cal-memos{display:flex;flex-direction:column;gap:4px}
.cal-chip{display:-webkit-box;width:100%;padding:3px 6px 3px 9px;border-radius:5px;font-size:11px;font-weight:600;line-height:1.35;white-space:normal;overflow:hidden;text-overflow:ellipsis;text-align:left;border:1px solid transparent;border-left-width:4px;-webkit-line-clamp:2;-webkit-box-orient:vertical;word-break:break-word}
.cal-chip-blue,.cal-memo-blue{background:#EEF2FF;color:#1E40AF;border-color:#C7D2FE;border-left-color:#2B5CE6}
.cal-chip-green,.cal-memo-green{background:#D1FAE5;color:#047857;border-color:#A7F3D0;border-left-color:#10B981}
.cal-chip-yellow,.cal-memo-yellow{background:#FEF3C7;color:#92400E;border-color:#FDE68A;border-left-color:#F59E0B}
.cal-chip-red,.cal-memo-red{background:#FEE2E2;color:#B91C1C;border-color:#FECACA;border-left-color:#EF4444}
.cal-chip-gray,.cal-memo-gray{background:#F3F4F6;color:#4B5563;border-color:#E5E7EB;border-left-color:#6B7280}
.cal-more{font-size:11px;color:var(--t2);font-weight:700;margin-top:1px}
.cal-empty{padding:30px;text-align:center;color:var(--t3);font-size:12.5px}
.cal-day-modal-body{max-height:70vh;overflow-y:auto}
.cal-day-list{display:flex;flex-direction:column;gap:10px}
.cal-day-item{border:1px solid var(--bd);border-left-width:4px;border-radius:8px;padding:10px;background:#fff;height:auto;min-height:0;overflow:visible}
.cal-day-h{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:6px}
.cal-day-title{font-size:13px;font-weight:800}
.cal-day-meta{font-size:11px;color:var(--t3);margin-top:2px}
.calendar-memo-content,.cal-day-content{white-space:pre-wrap;word-break:break-word;overflow-wrap:anywhere;user-select:text;font-size:12.5px;line-height:1.65;color:var(--t1);height:auto;min-height:0;max-height:none;overflow:visible}
.calendar-memo-textarea{min-height:160px;resize:vertical}
.cal-color-dot{width:9px;height:9px;border-radius:50%;display:inline-block;margin-right:5px}
.cal-color-blue{background:#2B5CE6}.cal-color-green{background:#10B981}.cal-color-yellow{background:#F59E0B}.cal-color-red{background:#EF4444}.cal-color-gray{background:#6B7280}
.leave-tabs{display:flex;gap:6px;margin-bottom:12px;flex-wrap:wrap}
.leave-tab{padding:6px 12px;border:1px solid var(--bd);border-radius:20px;background:#fff;color:var(--t2);font-size:12px;font-weight:700;cursor:pointer;transition:all .12s}
.leave-tab.on{background:var(--pr);border-color:var(--pr);color:#fff}
.leave-panel{display:none}
.leave-panel.on{display:block}
.leave-status-draft{background:#F3F4F6;color:#374151}
.leave-status-requested{background:#FEF3C7;color:#92400E}
.leave-status-approved{background:#D1FAE5;color:#047857}
.leave-status-rejected{background:#FEE2E2;color:#B91C1C}
.leave-status-canceled{background:#E5E7EB;color:#6B7280}
.leave-cal-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}
.leave-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);border:1px solid var(--bd);border-radius:8px;overflow:hidden;background:#fff}
.leave-cal-cell{min-height:110px;padding:8px;border-top:1px solid var(--bd);border-right:1px solid var(--bd);cursor:pointer;background:#fff}
.leave-cal-cell:nth-child(7n){border-right:none}
.leave-cal-cell:hover{background:#F8FAFF}
.leave-cal-cell.other{background:#FAFAFB;color:var(--t3)}
.leave-cal-day{font-size:12px;font-weight:800;margin-bottom:6px}
.leave-cal-today span{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:var(--pr);color:#fff}
.leave-chip{display:block;padding:3px 6px;border-radius:5px;font-size:11px;font-weight:700;line-height:1.35;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:left}
.leave-chip-requested{background:#FEF3C7;color:#92400E;border-left:4px solid #F59E0B}
.leave-chip-approved{background:#D1FAE5;color:#047857;border-left:4px solid #10B981}
.leave-day-list{display:flex;flex-direction:column;gap:10px}
.leave-day-item{border:1px solid var(--bd);border-radius:8px;padding:10px;background:#fff}
.work-schedule-toolbar{display:flex;align-items:center;gap:8px;margin-bottom:12px;flex-wrap:nowrap}
.work-schedule-filters{display:flex;align-items:center;gap:8px;flex-wrap:nowrap}
.work-schedule-toolbar .fsel{min-width:116px}
.work-schedule-weekdays{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding-top:6px}
.work-schedule-weekday{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--t2);font-weight:700}
.work-schedule-grid{display:grid;grid-template-columns:repeat(7,1fr);border:1px solid var(--bd);border-radius:8px;overflow:hidden;background:#fff}
.work-schedule-cell{min-height:116px;padding:8px;border-top:1px solid var(--bd);border-right:1px solid var(--bd);cursor:pointer;background:#fff}
.work-schedule-cell:nth-child(7n){border-right:none}
.work-schedule-cell:hover{background:#F8FAFF}
.work-schedule-cell.other{background:#FAFAFB;color:var(--t3)}
.work-schedule-day{font-size:12px;font-weight:800;margin-bottom:6px}
.work-schedule-today span{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:var(--pr);color:#fff}
.work-schedule-chip{display:block;padding:3px 6px;border-radius:5px;font-size:11px;font-weight:700;line-height:1.35;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:left;border-left:4px solid transparent}
.work-schedule-type-work{background:#EEF2FF;color:#1E40AF;border-left-color:#2B5CE6}
.work-schedule-type-off{background:#F3F4F6;color:#4B5563;border-left-color:#6B7280}
.work-schedule-type-early{background:#D1FAE5;color:#047857;border-left-color:#10B981}
.work-schedule-type-late{background:#FEF3C7;color:#92400E;border-left-color:#F59E0B}
.work-schedule-type-half{background:#EDE9FE;color:#6D28D9;border-left-color:#8B5CF6}
.work-schedule-type-etc{background:#F8FAFC;color:#334155;border-left-color:#94A3B8}
.work-schedule-type-leave-approved{background:#D1FAE5;color:#047857;border-left-color:#10B981}
.work-schedule-type-leave-requested{background:#FEF3C7;color:#92400E;border-left-color:#F59E0B}
.work-schedule-type-leave-hourly{background:#DBEAFE;color:#1D4ED8;border-left-color:#3B82F6}
.work-schedule-list{display:flex;flex-direction:column;gap:10px}
.work-schedule-item{border:1px solid var(--bd);border-radius:8px;padding:10px;background:#fff}
.work-schedule-section-title{font-size:12px;font-weight:800;color:var(--t2);margin:12px 0 8px}
.work-schedule-readonly-note{font-size:11px;color:var(--t3);margin-top:8px}
@media(max-width:1024px){
  .sidebar{position:fixed;top:0;left:0;height:100vh;transform:translateX(-100%);transition:transform .18s ease;box-shadow:var(--shm);z-index:calc(var(--z-sidebar) + 100)}
  .sidebar.mobile-open{transform:translateX(0)}
  .sidebar-backdrop{position:fixed;inset:0;background:rgba(17,24,39,.42);z-index:calc(var(--z-sidebar) + 90)}
  .sidebar-backdrop.open{display:block}
  .mobile-menu-btn{display:flex}
  .topbar{padding:0 16px}
  .content{padding:16px}
  .fg4,.fg5,.g4{grid-template-columns:repeat(2,minmax(0,1fr))}
  .frow{grid-template-columns:repeat(2,minmax(0,1fr))}
  .dashboard-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .dashboard-main-grid{grid-template-columns:1fr}
  .dashboard-prod-summary{grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media(max-width:767px){
  body{font-size:12.5px}
  .login-right{display:none}
  .login-left{width:100%;flex:1;padding:28px 20px}
  .login-logo{margin-bottom:28px}
  .login-form h2{font-size:20px}
  .login-form .sub{margin-bottom:24px}
  .topbar{padding:0 12px;gap:8px}
  .topbar-title{min-width:0;max-width:100%}
  .topbar-right{gap:8px}
  .topbar-userinfo .tu-role,.topbar-userinfo .tu-date{display:none}
  .topbar-userinfo .tu-name{max-width:92px;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .topbar-icons{gap:3px}
  .topbar-icons .ic-btn,.mobile-menu-btn{width:36px;height:36px}
  .user-dropdown,.notif-drop{right:12px;width:calc(100vw - 24px)}
  .lo-drop{right:12px}
  .content{padding:12px}
  .bom-search-popover,.fixture-product-search-popover{left:12px!important;right:12px!important;width:auto!important}
  .ph{align-items:stretch;flex-direction:column;gap:10px;margin-bottom:12px}
  .ph>.flex,.ch,.sec-btns{flex-wrap:wrap}
  .ph-title{font-size:17px}
  .card{padding:12px}
  .permission-tabs{display:grid;grid-template-columns:1fr 1fr;width:100%}
  .permission-tab{width:100%}
  .fbar{padding:12px;margin-bottom:10px}
  .bom-search-result-branches{white-space:normal;overflow:visible;text-overflow:clip;line-height:1.35}
  .fixture-product-search-box{grid-template-columns:1fr}
  .fixture-selected-title,.fixture-selected-meta,.fixture-product-result-branches{white-space:normal;overflow:visible;text-overflow:clip;line-height:1.35}
  .fg2,.fg3,.fg4,.fg5,.g2,.g3,.g4,.frow{grid-template-columns:1fr}
  .sp2,.sp3,.sp4{grid-column:span 1}
  .frow-text{align-items:stretch;flex-direction:column;gap:6px}
  .ftext-inp{max-width:none;width:100%}
  .frow-btns{display:grid;grid-template-columns:1fr 1fr;gap:8px}
  .frow-btns .btn{justify-content:center;width:100%;min-height:38px}
  .btn{min-height:36px;justify-content:center}
  .inp,.sel,.ta,.finput,.fsel,.lf-input{min-height:38px}
  #page-prod-entry .fbar{padding:10px 12px}
  #page-prod-entry .frow{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:8px}
  #page-prod-entry .fitem:last-child{grid-column:span 2}
  #page-prod-entry .flbl{font-size:10.5px}
  #page-prod-entry .finput,#page-prod-entry .fsel{height:var(--control-h);min-height:var(--control-h)}
  .tw{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .tw table{min-width:720px}
  .act-table{min-width:720px}
  #page-prod-entry .tw table{min-width:0}
  .prod-entry-table-wrap{display:none!important}
  .prod-entry-card-list{display:flex;flex-direction:column;gap:7px}
  .prod-entry-mobile-search{display:block;margin-bottom:8px}
  .prod-entry-mobile-save{display:none}
  .prod-entry-mobile-savebar{display:flex;position:sticky;bottom:0;z-index:60;background:rgba(255,255,255,.97);border-top:1px solid var(--bd);padding:9px 0 0;margin-top:10px;align-items:center;gap:8px}
  .prod-entry-mobile-savebar .btn{min-width:92px}
  .ptbl{min-width:980px!important}
  .ptbl input{width:58px;min-width:58px;height:28px}
  .cat-row,.eval-row,.eval-fields{flex-direction:column}
  .cat-row .cat-type,.eval-who,.eval-type{width:100%;min-width:0}
  .cat-row .cat-del{align-self:flex-end}
  .pgn{align-items:stretch;flex-direction:column;gap:8px}
  .pgn-btns{flex-wrap:wrap}
  .pager{justify-content:flex-start;gap:8px}
  .pager-info{width:100%;margin-right:0}
  .pager-buttons{width:100%}
  .pager-btn{min-width:30px;padding:0 7px}
  .dashboard-summary-grid,.dashboard-prod-summary{grid-template-columns:1fr}
  .dashboard-list-item{grid-template-columns:auto minmax(0,1fr);align-items:start}
  .dashboard-list-side{grid-column:2;text-align:left}
  .dashboard-branch-head{align-items:flex-start;flex-direction:column;gap:4px}
  .cal-toolbar,.calendar-toolbar,.leave-cal-toolbar{align-items:stretch;flex-direction:column}
  .cal-nav{justify-content:space-between}
  .cal-title{font-size:17px;min-width:auto}
  .calendar-year-select,.calendar-month-select{min-width:96px}
  .cal-cell,.leave-cal-cell,.work-schedule-cell{min-height:82px;padding:5px}
  .cal-dow{padding:7px 3px;font-size:10.5px}
  .cal-day,.leave-cal-day,.work-schedule-day{font-size:11px;margin-bottom:4px}
  .cal-day.today span,.cal-day.cal-today span,.leave-cal-today span,.work-schedule-today span{width:22px;height:22px}
  .cal-chip,.leave-chip,.work-schedule-chip{font-size:10px;padding:2px 4px;line-height:1.25}
  .cal-more{font-size:10px}
  .work-schedule-toolbar{align-items:stretch;flex-direction:column;flex-wrap:wrap}
  .work-schedule-filters{align-items:stretch;flex-direction:column;flex-wrap:wrap}
  .work-schedule-toolbar .fsel{min-width:0;width:100%}
  .mo{padding:12px}
  .mo-box{width:calc(100vw - 24px)!important;max-width:calc(100vw - 24px);max-height:88vh}
  .mo-hdr{padding:12px 14px}
  .mo-body{padding:14px;overflow-y:auto}
  .mo-foot{padding:12px 14px;flex-wrap:wrap}
  .mo-foot .btn{flex:1 1 120px}
  .bulk-upload-summary{grid-template-columns:repeat(2,minmax(0,1fr))}
  .bulk-upload-error-item{grid-template-columns:1fr;gap:4px}
  .guide-box{max-height:88vh}
  .guide-body{padding:0;overflow:hidden}
  .guide-intro{padding:13px 14px}
  .guide-layout{display:block}
  .guide-nav{display:flex;gap:6px;overflow-x:auto;overflow-y:hidden;max-height:none;border-right:none;border-bottom:1px solid var(--bd);padding:9px 10px;-webkit-overflow-scrolling:touch}
  .guide-nav-item{width:auto;white-space:nowrap;flex-shrink:0;padding:7px 9px;font-size:11.5px}
  .guide-content{padding:12px 14px 16px;max-height:calc(88vh - 190px)}
  .guide-section-title{font-size:15px}
  .guide-card{padding:11px}
  .conf-box{width:calc(100vw - 32px);padding:22px}
  .conf-btns{flex-wrap:wrap}
  .conf-btns .btn{flex:1 1 120px}
  .img-wrap{gap:8px}
  .img-add-btn,.img-thumb,.img-thumb img{width:86px}
  .img-add-btn,.img-thumb img{height:68px}
  .img-thumb .rm,.file-download-btn{width:24px;height:24px;font-size:12px}
  .file-name{max-width:86px}
  .imgv-box{max-width:calc(100vw - 24px);max-height:88vh}
  .imgv-box img{max-height:72vh}
  .imgv-controls{width:100%;justify-content:center;flex-wrap:wrap}
  .imgv-btn{min-height:38px;min-width:96px}
  .imgv-close{top:8px;right:8px;background:rgba(0,0,0,.45)}
  .toast{max-width:calc(100vw - 32px);padding:12px 18px;font-size:13px}
}
@media(max-width:480px){
  .login-left{padding:22px 16px}
  .login-logo-text{font-size:18px}
  .topbar{padding:0 8px}
  .topbar-userinfo{display:none}
  .topbar-icons .ic-btn,.mobile-menu-btn{width:34px;height:34px}
  .ph-title{font-size:16px}
  .frow-btns{grid-template-columns:1fr}
  .dashboard-list-item{grid-template-columns:1fr}
  .dashboard-list-side{grid-column:auto}
  .cal-cell,.leave-cal-cell,.work-schedule-cell{min-height:70px;padding:4px}
  .cal-chip,.leave-chip,.work-schedule-chip{padding:2px 3px;font-size:9.5px}
  .img-add-btn,.img-thumb,.img-thumb img{width:78px}
  .img-add-btn,.img-thumb img{height:64px}
  .file-name{max-width:78px}
}
@media(max-width:340px){
  #page-prod-entry .frow{grid-template-columns:1fr}
  #page-prod-entry .fitem:last-child{grid-column:auto}
  .prod-entry-compact-inputs{grid-template-columns:1fr}
}
.check-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:6px 10px;min-height:34px;padding:7px 8px;border:1px solid var(--line);border-radius:6px;background:var(--sf)}
.check-item{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--tx)}
.check-item input{width:14px;height:14px}
.product-branch-picker{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:6px;align-items:center}
.product-branch-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px;min-height:28px}
.product-branch-tag{display:inline-flex;align-items:center;gap:6px;height:28px;padding:0 8px;border-radius:999px;background:var(--sf);border:1px solid var(--line);font-size:12px;color:var(--tx)}
.product-branch-tag button{border:0;background:transparent;cursor:pointer;color:var(--t3);font-size:14px;line-height:1;padding:0}
.product-branch-tag button:hover{color:var(--er)}
.product-branch-empty{font-size:12px;color:var(--t3);line-height:28px}
.product-branch-hint{margin-top:6px;font-size:12px;color:var(--t3)}
.product-branch-warning{color:var(--er)}
.searchable-select-original,.searchable-select-native{position:absolute!important;opacity:0!important;pointer-events:none!important;width:1px!important;height:1px!important;margin:0!important;padding:0!important;border:0!important}
.searchable-select{width:100%;min-width:0;font-size:var(--control-font-size)}
.searchable-select-trigger{width:100%;height:var(--control-h);min-height:var(--control-h);display:flex;align-items:center;justify-content:space-between;gap:6px;padding:0 var(--control-padding-x);border:1px solid var(--control-border);border-radius:var(--control-radius);background:#fff;color:#111827;font-size:var(--control-font-size);line-height:1;text-align:left;cursor:pointer;box-sizing:border-box}
.searchable-select-value{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.searchable-select-arrow{flex:0 0 auto;color:#667085;font-size:11px;line-height:1}
.searchable-select-trigger:hover{border-color:#98a2b3}
.searchable-select.is-open .searchable-select-trigger,.searchable-select-trigger:focus{outline:none;border-color:var(--pr,#2724dc);box-shadow:0 0 0 2px rgba(39,36,220,.10)}
.searchable-select.is-disabled .searchable-select-trigger,.searchable-select-trigger:disabled{background:#f9fafb;color:#98a2b3;cursor:not-allowed;border-color:#d0d5dd}
.searchable-select.is-invalid .searchable-select-trigger{border-color:#f04438}
.searchable-select-dropdown{position:fixed;z-index:6000;display:none;background:#fff;border:1px solid var(--control-border);border-radius:8px;box-shadow:0 8px 20px rgba(16,24,40,.13);overflow:hidden;box-sizing:border-box;font-size:var(--control-font-size)}
.searchable-select-dropdown.is-open{display:flex;flex-direction:column}
.searchable-select-search{width:calc(100% - 12px);height:var(--control-h);min-height:var(--control-h);margin:6px;padding:0 var(--control-padding-x);border:1px solid var(--control-border);border-radius:var(--control-radius);background:#fff;color:#111827;font-size:var(--control-font-size);outline:none;box-sizing:border-box}
.searchable-select-search:focus{border-color:var(--pr,#2724dc);box-shadow:0 0 0 2px rgba(39,36,220,.10)}
.searchable-select-options{max-height:220px;overflow-y:auto;padding:3px}
.searchable-select-option{width:100%;min-height:30px;display:block;padding:6px 8px;border:0;border-radius:5px;background:transparent;color:#111827;font-size:var(--control-font-size);line-height:1.25;text-align:left;cursor:pointer}
.searchable-select-option:hover,.searchable-select-option.is-active{background:#f2f4f7}
.searchable-select-option.is-selected{background:#eef2ff;color:#111827;font-weight:600}
.searchable-select-empty{padding:10px;color:#98a2b3;font-size:12px;text-align:center}
.summary-card{border:1px solid var(--bd);border-radius:8px;background:#fff;padding:12px;box-shadow:var(--sh)}
.summary-label{font-size:11px;font-weight:700;color:var(--t2);margin-bottom:5px}
.summary-value{font-size:16px;font-weight:800;color:var(--t1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mini-list{display:flex;flex-direction:column;gap:6px}
.mini-list-item{width:100%;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 10px;border:1px solid var(--bd);border-radius:7px;background:#fff;color:var(--t1);font-size:12.5px;text-align:left;cursor:pointer}
.mini-list-item:hover{background:var(--sf2)}
.mini-list-item span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mini-list-item strong{font-family:'DM Sans',sans-serif;color:var(--pr)}
.cost-trend-summary{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:6px;margin:0 0 8px}
.cost-trend-summary-item{border:1px solid var(--bd);border-radius:6px;background:var(--sf2);padding:7px 8px;min-width:0}
.cost-trend-summary-item span{display:block;font-size:10.5px;font-weight:700;color:var(--t3);margin-bottom:2px}
.cost-trend-summary-item strong{display:block;font-size:12.5px;color:var(--t1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cost-trend-chart{min-height:300px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.cost-trend-svg{width:100%;height:300px}
.cost-axis{stroke:#d0d5dd;stroke-width:1}
.cost-grid{stroke:#eef2f7;stroke-width:1}
.cost-axis-title{fill:var(--t2);font-size:11px;font-weight:800}
.cost-axis-tick{fill:var(--t3);font-size:10.5px}
.cost-line{fill:none;stroke:var(--pr);stroke-width:3;stroke-linecap:round;stroke-linejoin:round}
.cost-point{fill:#fff;stroke:var(--pr);stroke-width:2}
.cost-point-label{fill:var(--t1);font-size:10.5px;font-weight:800;paint-order:stroke;stroke:#fff;stroke-width:3px;stroke-linejoin:round}
.cost-point-change{font-size:10px;font-weight:800;paint-order:stroke;stroke:#fff;stroke-width:3px;stroke-linejoin:round}
.cost-point-change.up{fill:#dc2626}.cost-point-change.down{fill:#2563eb}
.cost-report-row.is-selected{background:#eef2ff}
.cost-report-row.is-selected td{font-weight:700}
.mt12{margin-top:12px}
@media(max-width:768px){
  :root{--control-h:38px}
  .tenant-settings-fields{grid-template-columns:1fr}
  .tenant-image-grid{grid-template-columns:1fr}
  .tenant-upload-row{grid-template-columns:1fr}
  .searchable-select-option{min-height:34px}
  .searchable-select-dropdown{max-width:calc(100vw - 16px)}
  .cost-trend-summary{grid-template-columns:repeat(2,minmax(0,1fr))}
  .cost-point-change{display:none}
  .cost-point-label{font-size:9.5px}
}
