/* Responsive UI + compact mobile nav + theme button */
:root{--radius:12px}
html:not([data-theme]), html[data-theme="light"]{
  --bg:#f6f7fb; --panel:#ffffff; --card:#ffffff; --line:#e5e7eb; --text:#0f172a; --muted:#64748b; --accent:#2563eb; --danger:#ef4444; --ok:#16a34a; --warn:#b45309
}
html[data-theme="eyecare"]{
  --bg:#0f172a; --panel:#0b1324; --card:#111827; --line:#1f2937; --text:#e5e7eb; --muted:#a3a3a3; --accent:#60a5fa; --danger:#ef4444; --ok:#22c55e; --warn:#f59e0b
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Microsoft YaHei","PingFang SC";line-height:1.45}
a{color:var(--accent);text-decoration:none} a:hover{text-decoration:underline}

.topbar{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--panel);border-bottom:1px solid var(--line)}
.topbar-left{display:flex;gap:10px;align-items:center}
.brand{font-weight:700;letter-spacing:.2px;white-space:nowrap}
.hamburger{display:none;background:transparent;border:1px solid var(--line);border-radius:8px;padding:6px 10px;color:var(--text)}
.topbar-right{display:flex;gap:8px;align-items:center}
.btn-small{padding:4px 8px;font-size:12px}

.sidemenu{position:fixed;top:44px;left:0;bottom:0;width:220px;background:var(--panel);border-right:1px solid var(--line);transform:translateX(0);transition:transform .2s ease;z-index:90}
.sidemenu .sidemenu-inner{display:flex;flex-direction:column;padding:10px;gap:6px}
.sidemenu a{padding:8px 10px;border-radius:8px}
.sidemenu a:hover{background:rgba(0,0,0,.04)}

.container{margin:16px 16px 16px 236px;}

.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px;margin-bottom:16px;box-shadow:0 1px 0 rgba(0,0,0,.06)}
.row{display:flex;gap:12px;flex-wrap:wrap}.row .col{flex:1 1 260px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}

@media(max-width:960px){
  .hamburger{display:inline-flex}
  .sidemenu{transform:translateX(-100%);width:80%;max-width:280px}
  body.nav-open .sidemenu{transform:translateX(0)}
  .container{margin:12px}
  .topbar-right .show-nav{display:inline-flex}
}
@media(min-width:961px){
  .topbar-right .show-nav{display:none}
}

input,select,textarea,button{background:var(--panel);color:var(--text);border:1px solid #cbd5e1;border-radius:8px;padding:8px 10px;width:100%}
html[data-theme="eyecare"] input, html[data-theme="eyecare"] select, html[data-theme="eyecare"] textarea, html[data-theme="eyecare"] button{border-color:#334155}
button{cursor:pointer;width:auto}.btn{padding:8px 12px;border-radius:8px;display:inline-block}
.btn-primary{background:#1d4ed8;border-color:#1d4ed8;color:#fff}
.btn-danger{background:var(--danger);border-color:var(--danger);color:#fff}
.btn-ghost{background:transparent;border-color:#cbd5e1}

.table-wrap{overflow-x:auto}
.table{min-width:900px;width:100%;border-collapse:collapse}
.table th,.table td{border-bottom:1px solid var(--line);padding:10px 10px;vertical-align:top}
.table th{text-align:left;font-weight:600}

.badge{padding:2px 8px;border-radius:999px;font-size:12px;border:1px solid #cbd5e1}
.footer{padding:16px;text-align:center;color:var(--muted)}
.muted{color:var(--muted)}
hr{border:0;border-top:1px solid var(--line);margin:12px 0}
.copy{font-size:12px;color:var(--muted)}

.alert{padding:10px 12px;border:1px solid #374151;border-radius:8px;margin-bottom:12px}
.alert-ok{border-color:#14532d;background:rgba(20,83,45,.08)}
.alert-err{border-color:#7f1d1d;background:rgba(127,29,29,.08)}
.confirm-hint{color:var(--warn);font-size:12px}
form label{display:block;margin-bottom:6px;color:#334155;font-size:14px}
html[data-theme="eyecare"] form label{color:#cbd5e1}

h2,h3{margin:0 0 8px 0}
.sort a{color:#16a34a;text-decoration:none}.sort a:hover{text-decoration:underline}

.copyable{cursor:pointer;border-bottom:1px dashed #888;padding-bottom:1px}
.copyable:hover{opacity:.9}

/* === copyable truncation & tooltip === */
.copyable{ position:relative; }
.copyable[data-truncated="1"]{ border-bottom:1px dashed #888; }
.copyable:hover::after{
  content: attr(data-copy);
  position:absolute;
  left:0;
  top:100%;
  transform: translateY(6px);
  white-space:nowrap;
  max-width: 80vw;
  overflow: hidden;
  text-overflow: ellipsis;
  background: rgba(0,0,0,0.88);
  color:#fff;
  padding:6px 10px;
  border-radius:6px;
  font-size:12px;
  line-height:1.3;
  z-index:1000;
  box-shadow:0 6px 18px rgba(0,0,0,.2);
}
.copyable:hover::before{
  content:"";
  position:absolute;
  left:10px;
  top:100%;
  border:6px solid transparent;
  border-bottom-color: rgba(0,0,0,0.88);
}

/* 客户信息框样式 - 适配护眼模式 */
.client-info-box {
  margin-top: 8px;
  padding: 8px;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 4px;
  font-size: 0.9em;
}

.client-warning-box {
  margin-top: 8px;
  padding: 8px;
  background: rgba(239, 68, 68, 0.1);
  border: 1px solid var(--danger);
  border-radius: 4px;
  font-size: 0.9em;
  color: var(--danger);
}

.client-info-box.muted {
  color: var(--muted);
  background: rgba(100, 116, 139, 0.1);
}
