:root{
  --navy:#0a2540; --sea:#0d6efd; --teal:#06b6a8; --abyss:#061b30;
  --ink:#0f172a; --slate:#475569; --mist:#94a3b8; --line:#e2e8f0;
  --bg:#f1f5f9; --card:#ffffff; --soft:#f8fafc;
  --good:#10b981; --warn:#f59e0b; --bad:#ef4444; --info:#0ea5e9; --live:#e11d48;
  --shadow:0 1px 2px rgba(10,37,64,.06),0 4px 16px rgba(10,37,64,.06);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Noto Sans KR',sans-serif;background:var(--bg);color:var(--ink);font-size:14px;-webkit-font-smoothing:antialiased}
.mono{font-family:'JetBrains Mono',monospace;font-variant-numeric:tabular-nums}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,select,textarea{font-family:inherit;font-size:14px}
.app{display:flex;min-height:100vh}
.hidden{display:none!important}

/* ===== 로그인 ===== */
.login{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,#0a2540,#061b30,#0d3a6e)}
.login .box{background:#fff;border-radius:20px;padding:38px 34px;width:min(380px,92vw);box-shadow:0 20px 60px rgba(0,0,0,.35)}
.login .logo{width:54px;height:54px;border-radius:15px;background:linear-gradient(135deg,var(--teal),var(--sea));display:grid;place-items:center;font-size:28px;margin:0 auto 16px;box-shadow:0 8px 22px rgba(13,110,253,.4)}
.login h2{text-align:center;font-size:22px;font-weight:900;letter-spacing:-.5px}
.login p{text-align:center;color:var(--mist);font-size:13px;margin:4px 0 24px}
.login input{width:100%;padding:13px 15px;border:1px solid var(--line);border-radius:11px;margin-bottom:12px;outline:none}
.login input:focus{border-color:var(--sea);box-shadow:0 0 0 3px rgba(13,110,253,.12)}
.login button{width:100%;padding:13px;border-radius:11px;background:var(--sea);color:#fff;font-weight:700;font-size:15px;transition:.15s}
.login button:hover{background:#0b5ed7}
.login .err{color:var(--bad);font-size:13px;text-align:center;margin-bottom:12px;min-height:18px}

/* ===== Sidebar ===== */
.side{width:230px;background:linear-gradient(180deg,var(--navy),var(--abyss));color:#cbd5e1;display:flex;flex-direction:column;position:fixed;top:0;bottom:0;left:0;z-index:30}
.brand{padding:22px 20px 18px;display:flex;align-items:center;gap:11px;border-bottom:1px solid rgba(255,255,255,.07)}
.logo-s{width:38px;height:38px;border-radius:11px;background:linear-gradient(135deg,var(--teal),var(--sea));display:grid;place-items:center;font-size:20px;box-shadow:0 4px 14px rgba(13,110,253,.4)}
.brand b{color:#fff;font-size:18px;letter-spacing:-.5px;display:block;line-height:1}
.brand span{font-size:11px;color:#7dd3fc;letter-spacing:1px}
.nav{padding:14px 12px;flex:1;overflow:auto}
.nav .grp{font-size:10.5px;color:#5b7795;letter-spacing:1.5px;margin:14px 10px 6px;font-weight:700}
.nav button{display:flex;align-items:center;gap:11px;width:100%;padding:10px 12px;border-radius:9px;color:#cbd5e1;font-size:13.5px;font-weight:500;text-align:left;transition:.15s;margin-bottom:2px}
.nav button .ic{font-size:16px;width:20px;text-align:center}
.nav button:hover{background:rgba(255,255,255,.06);color:#fff}
.nav button.on{background:linear-gradient(90deg,rgba(13,110,253,.25),rgba(6,182,168,.12));color:#fff;box-shadow:inset 2px 0 0 var(--teal)}
.nav button.live{background:rgba(225,29,72,.15);color:#fda4af}
.nav button.live.on{background:linear-gradient(90deg,rgba(225,29,72,.4),rgba(225,29,72,.1));color:#fff;box-shadow:inset 2px 0 0 var(--live)}
.nav .badge{margin-left:auto;background:var(--bad);color:#fff;font-size:10px;font-weight:700;padding:2px 7px;border-radius:20px}
.nav .blink{margin-left:auto;width:8px;height:8px;border-radius:50%;background:var(--live);animation:pulse 1.2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.sidefoot{padding:12px 18px;border-top:1px solid rgba(255,255,255,.07);font-size:11px;color:#5b7795}
.sidefoot button{color:#7dd3fc;font-size:12px;margin-top:6px}

/* ===== Main ===== */
.main{flex:1;margin-left:230px}
.top{background:var(--card);border-bottom:1px solid var(--line);padding:14px 28px;display:flex;align-items:center;gap:12px;position:sticky;top:0;z-index:20}
.top .ham{display:none;font-size:22px;background:none}
.top h1{font-size:19px;font-weight:900;letter-spacing:-.5px}
.top .sub{font-size:12px;color:var(--mist);margin-top:1px}
.spacer{flex:1}
.weather{display:flex;align-items:center;gap:10px;background:var(--soft);border:1px solid var(--line);border-radius:11px;padding:8px 14px}
.weather small{font-size:11px;color:var(--slate);font-weight:700}
.switch{position:relative;width:46px;height:24px;border-radius:20px;background:var(--good);transition:.2s;cursor:pointer}
.switch.off{background:var(--bad)}
.switch::after{content:'';position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;transition:.2s;box-shadow:0 1px 3px rgba(0,0,0,.3)}
.switch.off::after{left:24px}
.wstat{font-size:12px;font-weight:700}.wstat.go{color:var(--good)}.wstat.no{color:var(--bad)}
.content{padding:26px 28px;max-width:1320px}
.view{display:none;animation:fade .25s}.view.on{display:block}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.loading{text-align:center;padding:60px;color:var(--mist)}

/* ===== KPI / Panels ===== */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;margin-bottom:24px}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:15px;padding:17px 18px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.kpi::before{content:'';position:absolute;top:0;left:0;width:4px;height:100%;background:var(--sea)}
.kpi.t::before{background:var(--teal)}.kpi.w::before{background:var(--warn)}.kpi.b::before{background:var(--bad)}.kpi.g::before{background:var(--good)}.kpi.l::before{background:var(--live)}
.kpi .lab{font-size:12px;color:var(--slate);font-weight:500;display:flex;align-items:center;gap:6px}
.kpi .val{font-size:27px;font-weight:900;margin-top:7px;letter-spacing:-1px}
.kpi .val small{font-size:14px;color:var(--mist);font-weight:700}
.kpi .delta{font-size:11px;margin-top:4px;font-weight:700}
.kpi .delta.up{color:var(--bad)}.kpi .delta.dn{color:var(--good)}
.panel{background:var(--card);border:1px solid var(--line);border-radius:15px;box-shadow:var(--shadow);margin-bottom:22px;overflow:hidden}
.phead{padding:16px 20px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.phead h3{font-size:15px;font-weight:700}
.phead .cnt{font-size:12px;color:var(--mist);font-weight:500}
.pbody{padding:18px 20px}
.tabs{display:flex;gap:6px;margin-bottom:18px;flex-wrap:wrap}
.tab{padding:9px 16px;border-radius:10px;background:var(--card);border:1px solid var(--line);font-size:13px;font-weight:700;color:var(--slate)}
.tab.on{background:var(--navy);color:#fff;border-color:var(--navy)}
.chips{display:flex;gap:6px;flex-wrap:wrap}
.chip{padding:6px 12px;border-radius:20px;background:var(--soft);border:1px solid var(--line);font-size:12px;font-weight:500;color:var(--slate)}
.chip.on{background:#dbeafe;border-color:var(--sea);color:var(--sea);font-weight:700}

/* ===== Table ===== */
.tablewrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;min-width:560px}
th{text-align:left;font-size:11px;color:var(--mist);font-weight:700;padding:9px 12px;border-bottom:2px solid var(--line);letter-spacing:.3px;white-space:nowrap}
td{padding:11px 12px;border-bottom:1px solid var(--line);font-size:13px;vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:var(--soft)}
.tag{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:7px;font-size:11px;font-weight:700;white-space:nowrap}
.tag.stock{background:#dcfce7;color:#15803d}.tag.resv{background:#fef9c3;color:#a16207}
.tag.sold{background:#e0e7ff;color:#4338ca}.tag.dead{background:#fee2e2;color:#b91c1c}.tag.quar{background:#fae8ff;color:#a21caf}
.tag.sel{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff}.tag.rand{background:#e2e8f0;color:#475569}
.tag.guar{background:#cffafe;color:#0e7490}.tag.done{background:#f1f5f9;color:#64748b}.tag.claim{background:#ffedd5;color:#c2410c}
.tag.band{background:#dcfce7;color:#166534}.tag.insta{background:#fce7f3;color:#be185d}.tag.tel{background:#dbeafe;color:#1e40af}
.dot{width:7px;height:7px;border-radius:50%;display:inline-block}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:15px}
.fish{background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:var(--shadow);transition:.15s}
.fish:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(10,37,64,.12)}
.fish .img{height:104px;background:linear-gradient(135deg,#e0f2fe,#cffafe);display:grid;place-items:center;font-size:42px;position:relative}
.fish .pin{position:absolute;top:8px;right:8px}
.fish .body{padding:11px 13px}
.fish .nm{font-weight:700;font-size:13.5px}
.fish .meta{font-size:11.5px;color:var(--slate);margin-top:3px}
.fish .pr{font-size:16px;font-weight:900;margin-top:7px;letter-spacing:-.5px}
.fish .row{display:flex;align-items:center;justify-content:space-between;margin-top:8px;gap:6px}
.bar{height:9px;border-radius:6px;background:#e2e8f0;overflow:hidden;margin-top:6px}
.bar i{display:block;height:100%;background:linear-gradient(90deg,var(--teal),var(--sea));border-radius:6px}
.bar.low i{background:linear-gradient(90deg,var(--warn),var(--bad))}
.btn{padding:7px 14px;border-radius:9px;font-size:12.5px;font-weight:700;transition:.15s}
.btn.pri{background:var(--sea);color:#fff}.btn.pri:hover{background:#0b5ed7}
.btn.sm{padding:5px 11px;font-size:11.5px}
.btn.gho{background:var(--soft);border:1px solid var(--line);color:var(--slate)}.btn.gho:hover{background:#fff;border-color:var(--sea);color:var(--sea)}
.btn.dng{background:#fef2f2;color:var(--bad);border:1px solid #fecaca}.btn.dng:hover{background:var(--bad);color:#fff}
.btn.live{background:var(--live);color:#fff}.btn.live:hover{background:#be123c}
.btn.ok{background:var(--good);color:#fff}.btn.ok:hover{background:#059669}
.empty{text-align:center;padding:46px;color:var(--mist)}
.note{background:#eff6ff;border:1px solid #bfdbfe;border-radius:12px;padding:14px 16px;font-size:13px;color:#1e40af;line-height:1.6;margin-bottom:20px}
.note b{color:#1e3a8a}
.legend{display:flex;gap:16px;flex-wrap:wrap;font-size:12px;color:var(--slate);margin-top:14px}
.legend span{display:flex;align-items:center;gap:6px}
.split{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.mini{font-size:12px;color:var(--slate)}
.flag{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;color:var(--warn);background:#fffbeb;border:1px solid #fde68a;padding:2px 8px;border-radius:7px}
input.fld,select.fld,textarea.fld{padding:9px 12px;border:1px solid var(--line);border-radius:9px;background:#fff;outline:none;width:100%}
input.fld:focus,select.fld:focus,textarea.fld:focus{border-color:var(--sea);box-shadow:0 0 0 3px rgba(13,110,253,.12)}

/* ===== 라이브 판매 ===== */
.livehdr{background:linear-gradient(120deg,#1e1b4b,#4c1d95);color:#fff;border-radius:16px;padding:18px 22px;margin-bottom:20px;display:flex;align-items:center;gap:18px;box-shadow:0 8px 28px rgba(76,29,149,.25);flex-wrap:wrap}
.livehdr .rec{display:flex;align-items:center;gap:8px;background:rgba(225,29,72,.25);padding:6px 14px;border-radius:20px;font-weight:700;font-size:13px}
.livehdr .rec .blink{width:9px;height:9px;border-radius:50%;background:var(--live);animation:pulse 1.2s infinite}
.livehdr .st{margin-left:auto;text-align:right}
.livehdr .st b{font-size:24px;font-weight:900;display:block;letter-spacing:-1px}
.livehdr .st span{font-size:12px;color:#c4b5fd}
.fish.sellable{cursor:pointer}
.fish.sellable:active{transform:scale(.97)}
.fish.picked{outline:3px solid var(--live);outline-offset:-1px}
.sellbar{position:fixed;left:230px;right:0;bottom:0;background:#fff;border-top:2px solid var(--live);box-shadow:0 -8px 30px rgba(0,0,0,.12);padding:14px 22px;display:flex;align-items:center;gap:12px;z-index:50;flex-wrap:wrap}
.sellbar .pick{font-weight:900;font-size:15px}
.sellbar .pick small{display:block;font-weight:500;color:var(--slate);font-size:12px}
.sellbar input,.sellbar select{padding:9px 12px;border:1px solid var(--line);border-radius:9px;outline:none}

/* ===== Modal ===== */
.modal-bg{position:fixed;inset:0;background:rgba(10,37,64,.5);display:grid;place-items:center;z-index:100;padding:18px}
.modal{background:#fff;border-radius:18px;width:min(460px,96vw);max-height:90vh;overflow:auto;box-shadow:0 24px 60px rgba(0,0,0,.35)}
.modal .mh{padding:18px 22px;border-bottom:1px solid var(--line);display:flex;align-items:center}
.modal .mh h3{font-size:17px;font-weight:800}
.modal .mh .x{margin-left:auto;font-size:22px;color:var(--mist)}
.modal .mb{padding:20px 22px;display:grid;gap:12px}
.modal label{font-size:12px;font-weight:700;color:var(--slate);display:block;margin-bottom:5px}
.modal .row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.modal .mf{padding:16px 22px;border-top:1px solid var(--line);display:flex;gap:10px;justify-content:flex-end}

/* toast */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--navy);color:#fff;padding:12px 22px;border-radius:30px;font-weight:700;font-size:13px;z-index:200;box-shadow:0 10px 30px rgba(0,0,0,.3);opacity:0;transition:.3s}
.toast.show{opacity:1;bottom:34px}
.toast.bad{background:var(--bad)}.toast.good{background:var(--good)}

/* ===== iPhone 노치·홈바 안전영역 + 넘침 방지 (전역) ===== */
html,body{overflow-x:hidden;width:100%;max-width:100%}
*{min-width:0}
.top{padding-top:calc(14px + env(safe-area-inset-top))}
.side{padding-top:env(safe-area-inset-top)}
.sellbar{padding-bottom:calc(14px + env(safe-area-inset-bottom))}
.login{padding-top:calc(20px + env(safe-area-inset-top));padding-bottom:calc(20px + env(safe-area-inset-bottom))}
.content{padding-bottom:48px}
.kpi .val{overflow-wrap:anywhere}
.kpi .lab{flex-wrap:wrap}
.tab{white-space:nowrap}
.fish .nm{overflow-wrap:anywhere}
.modal{padding-bottom:env(safe-area-inset-bottom)}

/* ===== 모바일 (이 업체는 모바일 전용) ===== */
@media(max-width:900px){
  .side{transform:translateX(-100%);transition:.25s;box-shadow:8px 0 30px rgba(0,0,0,.3)}
  .side.open{transform:translateX(0)}
  .main{margin-left:0}
  .top .ham{display:block;font-size:24px;padding:4px 6px}
  .split{grid-template-columns:1fr}
  .sellbar{left:0}
  .content{padding:16px 12px 48px}
  .weather small{display:none}
  /* 상단 제목: 부제 숨기고 제목은 넘치면 … 처리 (밑으로 안 내려가게) */
  .top{gap:8px}
  .top > div:first-of-type, .top > div:nth-of-type(1){min-width:0;flex:1}
  .top .sub{display:none}
  .top h1{font-size:17px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .modal .row2{grid-template-columns:1fr}
  /* 입력창 16px → iOS 자동 확대(줌) 방지 + 터치 편의 */
  input,select,textarea,input.fld,select.fld,textarea.fld,.login input{font-size:16px}
  input.fld,select.fld,textarea.fld{padding:12px 13px}
  /* 버튼·메뉴 터치 영역 확대 */
  .btn{padding:11px 16px;font-size:14px}
  .btn.sm{padding:9px 13px;font-size:13px}
  .nav button{padding:14px 12px;font-size:15px}
  .nav button .ic{font-size:18px}
  .tab{padding:11px 16px;font-size:14px}
  .chip{padding:8px 14px;font-size:13px}
  /* 모달: 저장 버튼 항상 보이게 고정 + 크고 꽉 차게 */
  .modal{width:100%;max-height:92vh;border-radius:18px 18px 0 0;align-self:flex-end}
  .modal-bg{place-items:end center}
  .modal .mb{padding:18px 18px;gap:14px}
  .modal .mf{position:sticky;bottom:0;background:#fff;padding:14px 18px;box-shadow:0 -4px 14px rgba(0,0,0,.06)}
  .modal .mf .btn{flex:1;padding:15px;font-size:16px}
  /* KPI 2열 고정 (좁은 화면 가독성) */
  .kpis{grid-template-columns:1fr 1fr;gap:10px}
  .kpi{padding:14px 14px}
  .kpi .val{font-size:20px;letter-spacing:-.3px;line-height:1.2}
  .kpi .val small{font-size:12px}
  /* 패널 헤더 액션 버튼 줄바꿈시 꽉 차게 */
  .phead .btn{flex:1;min-width:120px}
  .phead input.fld{flex:1;min-width:140px}
  /* 라이브 판매 바: 닉네임 한 줄, 확정 버튼 크게 */
  .sellbar{gap:8px;padding:12px}
  .sellbar .pick{flex-basis:100%;font-size:14px}
  .sellbar #liveNick{flex:1 1 100%}
  .sellbar .spacer{display:none}
  .sellbar .btn.live{flex:1;padding:13px}
  .sellbar input,.sellbar select{font-size:16px;padding:11px}
}
