/* IHOH DPB — Base Reset & Typography */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html,body{height:100%;-webkit-font-smoothing:antialiased;overscroll-behavior:none;}
body{font-family:var(--font-sans);font-size:14px;background:var(--page-bg);color:var(--ink);line-height:1.55;}
button{font-family:inherit;font-size:inherit;color:inherit;background:none;border:0;cursor:pointer;}
@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important;}}
@keyframes fadeInUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

.audit-banner-body{}
.audit-banner-title{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:3px;}
.audit-banner-text{font-size:12px;color:var(--muted);line-height:1.55;}

.ref-body{padding:var(--space-2) 0;}
.ref-item{
  display:flex;align-items:flex-start;gap:var(--space-3);
  padding:var(--space-3) var(--space-5);
  border-bottom:1px solid var(--border-subtle);
}
.ref-item:last-child{border-bottom:none;}
.ref-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0;margin-top:7px;}
.rd-warn{background:var(--warning);}
.rd-info{background:var(--info);}
.rd-ok  {background:var(--success);}
.rd-teal{background:var(--teal);}
.ref-text{font-size:13px;color:var(--muted);line-height:1.55;}
.ref-text strong{color:var(--ink);font-weight:500;}
.ref-text code{font-family:var(--font-mono);font-size:11px;color:var(--teal);background:var(--teal-dim);padding:1px 5px;border-radius:4px;}

.kv-card-body{padding:var(--space-5);}
.kv-field-row{margin-bottom:var(--space-4);}
.kv-label{display:block;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:var(--space-2);}
.kv-input{width:100%;background:var(--field);border:1px solid var(--field-border);border-radius:var(--radius);padding:9px 12px;font-family:var(--font-mono);font-size:12px;color:var(--ink);transition:border-color var(--t-fast);outline:none;}
.kv-input:focus{border-color:var(--teal);}
.kv-input::placeholder{color:var(--faint);}
.kv-input-secret{letter-spacing:.05em;}
.kv-field-actions{display:flex;justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-2);}
.kv-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:var(--radius);font-size:13px;font-weight:500;cursor:pointer;transition:background var(--t-fast),color var(--t-fast),opacity var(--t-fast);border:1px solid transparent;}
.kv-btn:disabled{opacity:.4;cursor:not-allowed;}
.kv-btn-ghost{background:var(--panel-raised);color:var(--muted);border-color:var(--border-subtle);}
.kv-btn-ghost:hover:not(:disabled){background:var(--field);color:var(--ink);}
.kv-btn-primary{background:var(--teal);color:var(--on-teal);font-weight:600;}
.kv-btn-primary:hover:not(:disabled){background:var(--teal-hover);}
.kv-btn-full{width:100%;margin-bottom:var(--space-2);}
.kv-btn-full:last-child{margin-bottom:0;}
.kv-status-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--field);border-radius:var(--radius);margin-bottom:var(--space-4);border:1px solid var(--border-subtle);}
.kv-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;background:var(--faint);transition:background var(--t-med);}
.kv-status-dot.ok{background:var(--success);box-shadow:0 0 6px rgba(0,196,140,.4);}
.kv-status-dot.error{background:var(--error);box-shadow:0 0 6px rgba(255,95,95,.4);}
.kv-status-dot.busy{background:var(--warning);animation:pulse .8s infinite;}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.kv-status-text{font-size:12px;color:var(--muted);}
.kv-sync-actions{margin-bottom:var(--space-5);}
.kv-note{font-size:11px;color:var(--faint);line-height:1.6;padding:var(--space-3) var(--space-4);background:var(--field);border-radius:var(--radius);border:1px solid var(--border-subtle);}
.kv-note strong{color:var(--muted);font-weight:500;}
.kv-endpoint-row{display:flex;align-items:center;gap:var(--space-3);background:var(--field);border-radius:var(--radius);padding:10px var(--space-4);border:1px solid var(--border-subtle);}
.kv-method{font-family:var(--font-mono);font-size:10px;font-weight:600;padding:2px 8px;border-radius:4px;flex-shrink:0;}
.kv-put{background:rgba(0,184,169,.15);color:var(--teal);}
.kv-get{background:rgba(74,158,255,.15);color:var(--info);}
.kv-endpoint-url{font-family:var(--font-mono);font-size:11px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;}
.kv-headers{display:flex;flex-direction:column;gap:2px;margin-top:var(--space-3);}
.kv-header-row{display:flex;gap:var(--space-4);padding:6px var(--space-4);background:var(--field);border-radius:6px;border:1px solid var(--border-subtle);}
.kv-header-key{font-family:var(--font-mono);font-size:11px;color:var(--teal);min-width:120px;}
.kv-header-val{font-family:var(--font-mono);font-size:11px;color:var(--muted);}
.kv-log-wrap{margin-top:var(--space-5);}
.kv-log-label{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin-bottom:var(--space-2);}
.kv-log{background:var(--field);border:1px solid var(--border-subtle);border-radius:var(--radius);min-height:100px;max-height:200px;overflow-y:auto;padding:var(--space-3);}
.kv-log-empty{font-size:12px;color:var(--faint);font-style:italic;}
.kv-log-entry{display:flex;gap:var(--space-3);align-items:flex-start;padding:4px 0;border-bottom:1px solid var(--border-subtle);font-size:11px;}
.kv-log-entry:last-child{border-bottom:none;}
.kv-log-time{font-family:var(--font-mono);color:var(--faint);flex-shrink:0;min-width:64px;}
.kv-log-msg{color:var(--muted);}
.kv-log-msg.ok{color:var(--success);}
.kv-log-msg.err{color:var(--error);}
.kv-log-msg.info{color:var(--info);}
#kv-lock-screen,#kv-set-screen{display:flex;align-items:center;justify-content:center;min-height:calc(100dvh - var(--topbar-h));background:var(--page-bg);}
.kv-lock-wrap{width:100%;max-width:360px;display:flex;flex-direction:column;align-items:center;gap:0;animation:fadeInUp .3s var(--ease);}
.kv-lock-icon{width:56px;height:56px;border-radius:var(--radius-xl);background:var(--teal-dim);border:1px solid var(--teal-soft);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-5);}
.kv-lock-title{font-size:20px;font-weight:700;letter-spacing:-.01em;color:var(--ink);margin-bottom:var(--space-2);text-align:center;}
.kv-lock-sub{font-size:13px;color:var(--muted);text-align:center;margin-bottom:var(--space-6);line-height:1.5;}
.kv-lock-field-wrap{width:100%;margin-bottom:var(--space-4);}
.kv-lock-input{width:100%;text-align:center;font-size:14px;letter-spacing:.05em;}
.kv-lock-error{font-size:12px;color:var(--error);text-align:center;min-height:18px;margin-top:var(--space-2);transition:opacity var(--t-fast);}
.kv-lock-btn{width:100%;padding:10px;font-size:14px;margin-bottom:var(--space-3);}
.kv-relock-btn{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:500;color:var(--muted);background:var(--panel-raised);border:1px solid var(--border-subtle);padding:4px 10px;border-radius:var(--radius-pill);cursor:pointer;margin-left:var(--space-4);vertical-align:middle;transition:background var(--t-fast),color var(--t-fast);}
.kv-relock-btn:hover{background:var(--field);color:var(--ink);}

.modal-body{padding:var(--space-5) var(--space-6);max-height:70vh;overflow-y:auto;}
.modal-footer{
  padding:var(--space-4) var(--space-6);
  border-top:1px solid var(--border-subtle);
  display:flex;gap:var(--space-3);justify-content:flex-end;
  background:var(--panel-raised);
}

.changelog-body{flex:1;min-width:0;}
.changelog-meta{
  display:flex;align-items:center;gap:var(--space-3);
  margin-bottom:var(--space-2);
}
.changelog-tag{
  font-size:10px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;
  padding:2px 8px;border-radius:var(--radius-pill);
}
.changelog-date{
  font-family:var(--font-mono);font-size:11px;color:var(--faint);
}
.changelog-entry-title{
  font-size:14px;font-weight:600;color:var(--ink);margin-bottom:4px;
}
.changelog-entry-text{
  font-size:13px;color:var(--muted);line-height:1.6;
}
.changelog-entry-actions{
  display:flex;gap:4px;align-items:flex-start;
  opacity:0;transition:opacity var(--t-fast);
  flex-shrink:0;
}

