/* ====================================================
   FAMS Dark Theme Override
   Applies dark design consistent with main.php
   ==================================================== */

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@300;400;500;700;900&family=Bebas+Neue&family=DM+Mono:wght@400;500&display=swap');

:root {
  --bg:      #06090f;
  --bg2:     #0b1018;
  --surface: #0f1620;
  --surface2:#141e2e;
  --border:  rgba(255,255,255,.07);
  --border2: rgba(255,255,255,.12);
  --accent:  #e85d04;
  --accent2: #ff8c42;
  --blue:    #1e3c72;
  --blue2:   #4facfe;
  --teal:    #0d9488;
  --teal2:   #00f2fe;
  --text:    #f0f4f8;
  --text-m:  #94a3b8;
  --text-s:  #546278;
  --r:       16px;
  --r-sm:    8px;
  --nav-h:   56px;
}

/* ── Base ── */
html { scroll-behavior: smooth; }

body {
  font-family: 'Noto Sans KR', 'Malgun Gothic', sans-serif !important;
  background: var(--bg) !important;
  color: var(--text) !important;
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
}

body::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: radial-gradient(ellipse 80% 50% at 50% 0%, black 0%, transparent 100%);
  pointer-events: none;
  z-index: 0;
}

::-webkit-scrollbar { width: 4px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: var(--surface2); border-radius: 2px; }

/* ── Dark Nav Bar (replaces old .header) ── */
.header {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  z-index: 1000 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 0 24px !important;
  height: var(--nav-h) !important;
  background: rgba(6,9,15,.92) !important;
  backdrop-filter: blur(16px) !important;
  -webkit-backdrop-filter: blur(16px) !important;
  border-bottom: 1px solid var(--border) !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  margin: 0 !important;
  max-width: 100% !important;
}

.header h1, .header h2 {
  font-family: 'Noto Sans KR', sans-serif !important;
  font-size: .95rem !important;
  font-weight: 700 !important;
  color: var(--text) !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  letter-spacing: normal !important;
  margin: 0 !important;
  text-shadow: none !important;
  -webkit-text-fill-color: unset !important;
  background: none !important;
  -webkit-background-clip: unset !important;
}

.header h1::before {
  content: '🔥' !important;
  font-size: 1.1rem !important;
}

.header p {
  display: none !important;
}

/* ── Header button group ── */
.btn-nav-back {
  display: inline-flex !important;
  align-items: center !important;
  gap: 4px !important;
  padding: 5px 13px !important;
  background: rgba(232,93,4,.12) !important;
  border: 1px solid rgba(232,93,4,.3) !important;
  border-radius: 20px !important;
  color: var(--accent2, #ff8c42) !important;
  font-size: .78rem !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  flex-shrink: 0 !important;
  transition: all .2s !important;
}

.btn-nav-back:hover {
  background: rgba(232,93,4,.22) !important;
  border-color: rgba(232,93,4,.5) !important;
}

.btn-group-header {
  display: flex !important;
  gap: 8px !important;
  flex-wrap: nowrap !important;
  overflow-x: auto !important;
  -webkit-overflow-scrolling: touch !important;
  scrollbar-width: none !important;
  align-items: center !important;
}

.btn-group-header::-webkit-scrollbar {
  display: none !important;
}

.btn-group-header .btn,
.btn-group-header button {
  padding: 6px 14px !important;
  border-radius: var(--r-sm) !important;
  font-size: .78rem !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  border: 1px solid var(--border2) !important;
  background: var(--surface2) !important;
  color: var(--text-m) !important;
  transition: all .2s !important;
  text-decoration: none !important;
  min-height: 34px !important;
}

.btn-group-header .btn:hover,
.btn-group-header button:hover {
  background: var(--surface) !important;
  color: var(--text) !important;
  border-color: rgba(255,255,255,.2) !important;
}

.btn-group-header .btn[style*="color:red"],
.btn-group-header button[style*="color:red"] {
  border-color: rgba(232,93,4,.4) !important;
  color: var(--accent2) !important;
}

/* ── Container / Layout ── */
.container {
  background: transparent !important;
  position: relative;
  z-index: 1;
  padding-top: calc(var(--nav-h) + 24px) !important;
}

/* ── Cards / Panels / Boxes ── */
.card,
.stat-card,
.info-card,
.detail-card,
.section-card,
.panel,
.box,
.schedule-item,
.work-item,
.event-item,
.equipment-card,
.equipment-group,
.equipment-section,
.employee-card,
.doc-card,
.form-section,
.form-group-box,
.modal-content {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--r) !important;
  color: var(--text) !important;
}

/* ── White backgrounds → dark ── */
div[style*="background: white"],
div[style*="background:white"],
div[style*="background-color: white"],
div[style*="background-color:#fff"],
div[style*="background: #fff"],
div[style*="background-color: #ffffff"],
div[style*="background: #ffffff"] {
  background: var(--surface) !important;
}

/* ── Tables ── */
table {
  border-collapse: collapse !important;
  width: 100% !important;
  color: var(--text) !important;
}

th {
  background: var(--surface2) !important;
  color: var(--text-m) !important;
  border: 1px solid var(--border) !important;
  padding: 10px 14px !important;
  font-weight: 600 !important;
  font-size: .8rem !important;
  text-transform: uppercase !important;
  letter-spacing: .5px !important;
}

td {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  color: var(--text) !important;
  padding: 10px 14px !important;
}

tr:hover td {
  background: var(--surface2) !important;
}

/* ── Calendar cells ── */
.calendar-day,
.calendar-cell,
.day-cell,
.cal-day {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  color: var(--text) !important;
}

.calendar-day.today,
.today {
  background: rgba(79,172,254,.12) !important;
  border-color: rgba(79,172,254,.35) !important;
}

.calendar-day.other-month,
.other-month {
  background: var(--bg2) !important;
  color: var(--text-s) !important;
}

.calendar-header-day,
.day-header {
  background: var(--surface2) !important;
  color: var(--text-m) !important;
}

/* ── Stat cards ── */
.stat-card {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--r) !important;
  padding: 20px !important;
  text-align: center !important;
}

.stat-number,
.stat-value {
  color: var(--blue2) !important;
  font-weight: 700 !important;
}

.stat-label {
  color: var(--text-m) !important;
  font-size: .8rem !important;
}

/* ── Section headers ── */
.section-title,
.section-header h2,
.section-header h3,
h2, h3 {
  color: var(--text) !important;
}

/* ── Calendar nav ── */
.calendar-header,
.calendar-nav-bar {
  background: var(--surface2) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--r-sm) !important;
  padding: 12px 16px !important;
  margin-bottom: 12px !important;
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
}

.current-month,
.month-title {
  color: var(--text) !important;
  font-weight: 700 !important;
  font-size: 1.1rem !important;
}

/* ── Buttons ── */
.btn,
button:not(.btn-group-header button) {
  font-family: 'Noto Sans KR', sans-serif !important;
}

.btn-nav,
.btn-today,
.btn-prev,
.btn-next {
  background: var(--surface2) !important;
  border: 1px solid var(--border2) !important;
  color: var(--text-m) !important;
  border-radius: var(--r-sm) !important;
  padding: 6px 14px !important;
  cursor: pointer !important;
  transition: all .2s !important;
}

.btn-nav:hover,
.btn-today:hover {
  background: var(--surface) !important;
  color: var(--text) !important;
}

/* ── Status badges ── */
.status-normal,
.badge-normal { background: rgba(16,185,129,.15) !important; color: #34d399 !important; border: 1px solid rgba(16,185,129,.3) !important; }
.status-need-check,
.badge-warning { background: rgba(245,158,11,.15) !important; color: #fbbf24 !important; border: 1px solid rgba(245,158,11,.3) !important; }
.status-defect,
.badge-danger  { background: rgba(239,68,68,.15) !important; color: #fb7185 !important; border: 1px solid rgba(239,68,68,.3) !important; }
.status-disposed,
.badge-secondary { background: rgba(100,116,139,.15) !important; color: var(--text-s) !important; border: 1px solid var(--border) !important; }

/* ── Forms ── */
input[type=text],
input[type=number],
input[type=email],
input[type=date],
input[type=time],
input[type=password],
input[type=search],
select,
textarea {
  background: rgba(255,255,255,.92) !important;
  border: 1px solid rgba(255,255,255,.2) !important;
  color: #1a1a2e !important;
  border-radius: var(--r-sm) !important;
  padding: 8px 12px !important;
  font-family: 'Noto Sans KR', sans-serif !important;
  font-size: .88rem !important;
  transition: border-color .2s, box-shadow .2s !important;
}

input[type=text]:focus,
input[type=number]:focus,
input[type=email]:focus,
input[type=date]:focus,
input[type=time]:focus,
input[type=password]:focus,
input[type=search]:focus,
select:focus,
textarea:focus {
  outline: none !important;
  border-color: var(--blue2) !important;
  box-shadow: 0 0 0 3px rgba(79,172,254,.2) !important;
  background: #ffffff !important;
}

input::placeholder,
textarea::placeholder {
  color: #8a9ab5 !important;
}

select option {
  background: #fff !important;
  color: #1a1a2e !important;
}

label {
  color: var(--text-m) !important;
}

/* ── Action buttons ── */
.btn-primary, .btn-blue {
  background: linear-gradient(135deg, var(--blue), var(--blue2)) !important;
  border: none !important;
  color: white !important;
  border-radius: var(--r-sm) !important;
  padding: 8px 16px !important;
  cursor: pointer !important;
  font-weight: 600 !important;
  transition: all .2s !important;
}

.btn-success, .btn-green {
  background: linear-gradient(135deg, #059669, #10b981) !important;
  border: none !important;
  color: white !important;
}

.btn-warning, .btn-yellow {
  background: linear-gradient(135deg, #d97706, #f59e0b) !important;
  border: none !important;
  color: white !important;
}

.btn-danger, .btn-red, .btn-delete {
  background: linear-gradient(135deg, #dc2626, #ef4444) !important;
  border: none !important;
  color: white !important;
}

.btn-qr   { background: linear-gradient(135deg, #0e7490, #06b6d4) !important; border: none !important; color: white !important; }
.btn-inspect { background: linear-gradient(135deg, #059669, #10b981) !important; border: none !important; color: white !important; }
.btn-edit { background: linear-gradient(135deg, #b45309, #f59e0b) !important; border: none !important; color: #fff !important; }
.btn-history { background: var(--surface2) !important; border: 1px solid var(--border2) !important; color: var(--text-m) !important; }
.btn-white { background: var(--surface2) !important; border: 1px solid var(--border2) !important; color: var(--text-m) !important; }

/* ── Section / Container boxes ── */
.stats-section {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)) !important;
  gap: 12px !important;
  margin-bottom: 20px !important;
}

/* ── Equipment group header ── */
.equipment-header,
.group-header,
.list-header {
  background: var(--surface2) !important;
  border-bottom: 1px solid var(--border) !important;
  color: var(--text-m) !important;
  padding: 10px 16px !important;
  border-radius: var(--r-sm) var(--r-sm) 0 0 !important;
}

/* ── Modal ── */
.modal-overlay,
.modal-backdrop {
  background: rgba(0,0,0,.7) !important;
}

.modal-content,
.modal-box {
  background: var(--surface) !important;
  border: 1px solid var(--border2) !important;
  border-radius: var(--r) !important;
  color: var(--text) !important;
}

.modal-header {
  background: var(--surface2) !important;
  border-bottom: 1px solid var(--border) !important;
  border-radius: var(--r) var(--r) 0 0 !important;
  padding: 16px 20px !important;
  color: var(--text) !important;
}

/* ── Footer ── */
.footer,
footer {
  background: var(--bg2) !important;
  border-top: 1px solid var(--border) !important;
  color: var(--text-s) !important;
}

/* ── Pagination ── */
.pagination a,
.page-link {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  color: var(--text-m) !important;
  border-radius: var(--r-sm) !important;
}

.pagination a:hover,
.page-link:hover {
  background: var(--surface2) !important;
  color: var(--text) !important;
}

.pagination .active a,
.page-link.active {
  background: var(--blue) !important;
  color: white !important;
  border-color: var(--blue) !important;
}

/* ── Alert / Notice boxes ── */
.alert-info, .notice-info {
  background: rgba(79,172,254,.1) !important;
  border: 1px solid rgba(79,172,254,.25) !important;
  color: var(--blue2) !important;
  border-radius: var(--r-sm) !important;
}

.alert-warning, .notice-warning {
  background: rgba(245,158,11,.1) !important;
  border: 1px solid rgba(245,158,11,.25) !important;
  color: #fbbf24 !important;
}

.alert-danger, .notice-danger {
  background: rgba(239,68,68,.1) !important;
  border: 1px solid rgba(239,68,68,.25) !important;
  color: #fb7185 !important;
}

/* ── Employee / Personnel cards ── */
.employee-info,
.detail-section,
.info-section {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--r) !important;
  padding: 20px !important;
}

/* ── Nav menu (employee_index style) ── */
.nav-menu {
  background: var(--surface2) !important;
  border-bottom: 1px solid var(--border) !important;
  padding: 8px 0 !important;
  position: sticky !important;
  top: var(--nav-h) !important;
  z-index: 100 !important;
}

.nav-btn {
  background: transparent !important;
  border: 1px solid transparent !important;
  color: var(--text-m) !important;
  border-radius: var(--r-sm) !important;
  padding: 6px 14px !important;
  cursor: pointer !important;
  transition: all .2s !important;
}

.nav-btn:hover,
.nav-btn.active {
  background: var(--surface) !important;
  border-color: var(--border2) !important;
  color: var(--text) !important;
}

/* ── Filters / Search bar ── */
.filter-section,
.search-bar,
.filter-bar {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--r) !important;
  padding: 16px !important;
  margin-bottom: 16px !important;
}

/* ── Inspection info rows ── */
.inspection-info,
.info-row,
.detail-row {
  border-bottom: 1px solid var(--border) !important;
  color: var(--text-m) !important;
}

.info-label,
.detail-label {
  color: var(--text-s) !important;
  font-size: .8rem !important;
}

.info-value,
.detail-value {
  color: var(--text) !important;
  font-weight: 500 !important;
}

/* ── Doc index cards ── */
.doc-card,
.doc-item {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--r) !important;
  transition: all .3s !important;
}

.doc-card:hover,
.doc-item:hover {
  transform: translateY(-4px) !important;
  border-color: var(--border2) !important;
  box-shadow: 0 12px 32px rgba(0,0,0,.4) !important;
}

/* ── Fix: override inline white/light colors ── */
[style*="color: #333"],
[style*="color:#333"] { color: var(--text) !important; }
[style*="color: #666"],
[style*="color:#666"] { color: var(--text-m) !important; }
[style*="color: #999"],
[style*="color:#999"] { color: var(--text-s) !important; }
[style*="background-color: #f5f5f5"],
[style*="background: #f5f5f5"] { background: var(--surface) !important; }
[style*="background-color: white"],
[style*="background-color: #fff"],
[style*="background: white"],
[style*="background: #fff"] { background: var(--surface) !important; }

/* ── map_monitoring.php: .main-tabs nav ── */
.main-tabs {
  background: rgba(6,9,15,.92) !important;
  backdrop-filter: blur(16px) !important;
  border-bottom: 1px solid var(--border) !important;
  box-shadow: none !important;
}

.tab-button {
  background: transparent !important;
  color: var(--text-m) !important;
  border-bottom: 3px solid transparent !important;
  transition: all .2s !important;
}

.tab-button:hover,
.tab-button.active {
  background: rgba(255,255,255,.05) !important;
  color: var(--text) !important;
  border-bottom-color: var(--blue2) !important;
}

/* ── map panel, equipment panel etc ── */
.monitoring-panel,
.editor-panel,
.map-panel,
.side-panel,
.info-panel {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
}

/* ── Lists without .header class ── */
.list-title,
.page-title,
.section-title {
  color: var(--text) !important;
}

/* ── Failure/inspection items ── */
.failure-item,
.inspection-item,
.work-item,
.schedule-item {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--r-sm) !important;
  color: var(--text) !important;
}

.failure-item:hover,
.inspection-item:hover,
.work-item:hover,
.schedule-item:hover {
  background: var(--surface2) !important;
  border-color: var(--border2) !important;
}

/* ── Priority / urgency badges ── */
.priority-urgent,
.urgency-high,
.badge-urgent { background: rgba(239,68,68,.15) !important; color: #fb7185 !important; border: 1px solid rgba(239,68,68,.3) !important; }
.priority-normal,
.urgency-normal,
.badge-medium { background: rgba(245,158,11,.15) !important; color: #fbbf24 !important; border: 1px solid rgba(245,158,11,.3) !important; }
.priority-low,
.urgency-low { background: rgba(16,185,129,.15) !important; color: #34d399 !important; border: 1px solid rgba(16,185,129,.3) !important; }

/* ── Calendar event dots / items ── */
.event-dot,
.cal-event {
  border-radius: 4px !important;
  font-size: .72rem !important;
  padding: 2px 6px !important;
}

/* ── Generic white bg cleanup ── */
[class*="wrap"],
[class*="wrapper"],
[class*="inner"],
[class*="content"]:not(script):not(style) {
  background-color: transparent;
}

/* ── Doc inspection forms: print-style forms need separate handling ── */
.form-table {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--r) !important;
}

.form-table th {
  background: var(--surface2) !important;
  color: var(--text-m) !important;
}

.form-table td {
  background: var(--surface) !important;
  color: var(--text) !important;
}

/* ── Scrollbar ── */
::-webkit-scrollbar { width: 4px; height: 4px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: var(--surface2); border-radius: 2px; }

/* ============================================================
   RESPONSIVE / MOBILE
   ============================================================ */

/* ── Tablet (≤ 1024px) ── */
@media (max-width: 1024px) {
  .container {
    max-width: 100% !important;
    padding-left: 20px !important;
    padding-right: 20px !important;
  }

  .stats-section {
    grid-template-columns: repeat(2, 1fr) !important;
  }

  .equipment-grid,
  [class*="equipment-grid"] {
    grid-template-columns: repeat(2, 1fr) !important;
  }

  table {
    font-size: .82rem !important;
  }

  th, td {
    padding: 8px 10px !important;
  }
}

/* ── Mobile (≤ 768px) ── */
@media (max-width: 768px) {

  /* ── 헤더: static 블록 (fixed 아님) - 자연스러운 흐름 ── */
  .header {
    position: static !important;
    height: auto !important;
    min-height: unset !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    padding: 16px 16px 12px !important;
    gap: 10px !important;
    border-radius: 0 0 14px 14px !important;
    margin-bottom: 16px !important;
    border-bottom: 1px solid rgba(255,255,255,.08) !important;
  }

  .header h1,
  .header h2 {
    font-size: 1.05rem !important;
    white-space: normal !important;
    overflow: visible !important;
    text-overflow: unset !important;
    max-width: 100% !important;
    line-height: 1.3 !important;
  }

  .header h1::before {
    display: inline !important;
  }

  /* btn-nav-back: 헤더 안에서 자연스럽게 */
  .btn-nav-back {
    font-size: .75rem !important;
    padding: 5px 12px !important;
  }

  /* ── 버튼 그룹: 헤더 안 가로 스크롤 버튼 행 ── */
  .btn-group-header {
    position: static !important;
    width: 100% !important;
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    align-items: center !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
    scrollbar-width: none !important;
    gap: 8px !important;
    padding: 0 !important;
    background: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    border: none !important;
  }

  .btn-group-header::-webkit-scrollbar {
    display: none !important;
  }

  /* 버튼 스타일 - 둥근 pill 형태 */
  .btn-group-header .btn,
  .btn-group-header button {
    display: inline-flex !important;
    align-items: center !important;
    white-space: nowrap !important;
    flex-shrink: 0 !important;
    padding: 8px 16px !important;
    font-size: .78rem !important;
    font-weight: 600 !important;
    min-height: 36px !important;
    border-radius: 10px !important;
    border: 1px solid rgba(255,255,255,.15) !important;
    background: rgba(255,255,255,.08) !important;
    color: var(--text, #f0f4f8) !important;
    cursor: pointer !important;
    transition: all .18s !important;
    text-decoration: none !important;
  }

  .btn-group-header .btn:active,
  .btn-group-header button:active {
    background: rgba(255,255,255,.16) !important;
    transform: scale(.97) !important;
  }

  /* inline color:red 버튼 (메인이동 버튼 호환) */
  .btn-group-header .btn[style*="color:red"],
  .btn-group-header button[style*="color:red"] {
    background: rgba(232,93,4,.18) !important;
    border-color: rgba(232,93,4,.4) !important;
    color: var(--accent2, #ff8c42) !important;
  }

  /* Container: 헤더가 static이므로 padding-top 불필요 */
  .container {
    padding-top: 0 !important;
    padding-left: 14px !important;
    padding-right: 14px !important;
    padding-bottom: 24px !important;
  }

  /* Stats */
  .stats-section {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 8px !important;
    margin-bottom: 14px !important;
  }

  .stat-card {
    padding: 14px 10px !important;
    border-radius: 10px !important;
  }

  .stat-number, .stat-value {
    font-size: 1.4rem !important;
  }

  .stat-label {
    font-size: .72rem !important;
  }

  /* Calendar */
  .calendar-header,
  .calendar-nav-bar {
    flex-wrap: wrap !important;
    gap: 8px !important;
    padding: 10px 12px !important;
  }

  /* Calendar 7-col grid - compress on mobile */
  [style*="grid-template-columns: repeat(7"],
  .calendar-grid,
  .cal-grid {
    font-size: .7rem !important;
  }

  .calendar-day,
  .calendar-cell,
  .day-cell,
  .cal-day {
    min-height: 60px !important;
    padding: 4px !important;
    font-size: .68rem !important;
  }

  .calendar-header-day,
  .day-header {
    padding: 6px 2px !important;
    font-size: .68rem !important;
  }

  /* Equipment grid */
  .equipment-grid,
  [class*="equipment-grid"] {
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }

  /* Search/Filter box */
  .search-box,
  .filter-section,
  .filter-bar,
  .search-bar {
    flex-direction: column !important;
    gap: 8px !important;
    padding: 12px !important;
  }

  .search-box input,
  .search-box select,
  .filter-section input,
  .filter-section select,
  .filter-bar input,
  .filter-bar select {
    width: 100% !important;
    min-width: 0 !important;
  }

  /* Tables - horizontal scroll */
  .table-container,
  .table-wrap,
  [class*="table-wrap"] {
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
    border-radius: var(--r) !important;
  }

  table {
    min-width: 600px !important;
    font-size: .78rem !important;
  }

  th, td {
    padding: 8px 10px !important;
    white-space: nowrap !important;
  }

  /* ── Nav menu (employee_index 등): 헤더 안 가로 스크롤 탭 ── */
  .nav-menu {
    position: static !important;
    width: 100% !important;
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
    scrollbar-width: none !important;
    gap: 6px !important;
    padding: 0 !important;
    margin: 0 !important;
    background: none !important;
    border: none !important;
    border-radius: 0 !important;
  }

  .nav-menu::-webkit-scrollbar { display: none !important; }

  .nav-btn {
    display: inline-flex !important;
    align-items: center !important;
    white-space: nowrap !important;
    flex-shrink: 0 !important;
    padding: 8px 14px !important;
    font-size: .76rem !important;
    font-weight: 600 !important;
    min-height: 36px !important;
    border-radius: 10px !important;
    border: 1px solid rgba(255,255,255,.15) !important;
    background: rgba(255,255,255,.08) !important;
    color: var(--text, #f0f4f8) !important;
    text-decoration: none !important;
    cursor: pointer !important;
    transition: all .15s !important;
  }

  .nav-btn:hover,
  .nav-btn.active {
    background: rgba(79,172,254,.18) !important;
    border-color: rgba(79,172,254,.35) !important;
    color: var(--blue2, #4facfe) !important;
  }

  /* Buttons */
  .btn-group-header button,
  .btn-group-header .btn {
    font-size: .73rem !important;
    padding: 5px 10px !important;
  }

  /* Form layout */
  .form-row,
  .form-group {
    flex-direction: column !important;
    gap: 8px !important;
  }

  input[type=text],
  input[type=number],
  input[type=email],
  input[type=date],
  input[type=time],
  input[type=password],
  input[type=search],
  select,
  textarea {
    width: 100% !important;
    font-size: 16px !important; /* prevent iOS zoom */
  }

  /* Modal */
  .modal-content,
  .modal-box {
    width: 94vw !important;
    max-width: 94vw !important;
    margin: 10px auto !important;
    border-radius: 12px !important;
  }

  /* Employee / personnel cards */
  .employee-grid,
  [class*="card-grid"],
  [class*="grid-cols"] {
    grid-template-columns: 1fr !important;
  }

  /* Action button rows */
  .btn-actions,
  .action-row,
  [class*="btn-row"] {
    flex-wrap: wrap !important;
    gap: 6px !important;
  }

  .btn-actions button,
  .btn-actions a,
  .action-row button {
    flex: 1 !important;
    min-width: 80px !important;
    text-align: center !important;
    justify-content: center !important;
  }

  /* Detail view */
  .detail-section,
  .info-section,
  .employee-info {
    padding: 14px !important;
  }

  /* map_monitoring tabs */
  .main-tabs {
    overflow-x: auto !important;
    white-space: nowrap !important;
    -webkit-overflow-scrolling: touch !important;
  }

  .tab-button {
    padding: 12px 16px !important;
    font-size: .82rem !important;
  }
}

/* ── Small Mobile (≤ 480px) ── */
@media (max-width: 480px) {

  .header h1,
  .header h2 {
    font-size: .82rem !important;
  }

  /* 서브탭바 버튼 소형 화면 조정 */
  .btn-group-header .btn,
  .btn-group-header button {
    padding: 5px 11px !important;
    font-size: .7rem !important;
    min-height: 30px !important;
  }

  .stats-section {
    grid-template-columns: repeat(2, 1fr) !important;
  }

  .stat-card {
    padding: 10px 8px !important;
  }

  .stat-number {
    font-size: 1.2rem !important;
  }

  /* Calendar days compact */
  .calendar-day,
  .calendar-cell {
    min-height: 48px !important;
    padding: 2px !important;
    font-size: .62rem !important;
  }

  /* Calendar events - only show count */
  .calendar-event-label {
    display: none !important;
  }

  table {
    font-size: .72rem !important;
  }

  th, td {
    padding: 6px 8px !important;
  }
}

/* ── Ensure tables inside pages without .table-container still scroll ── */
@media (max-width: 768px) {
  .container > table,
  .container > div > table {
    display: block !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
    max-width: 100% !important;
  }
}

/* ── Viewport meta tag for pages missing it (CSS fallback) ── */
@media (max-width: 768px) {
  html {
    -webkit-text-size-adjust: 100% !important;
  }
}


/* ═══════════════════════════════════════════════════════════
   ENHANCED MOBILE RESPONSIVE FIXES
   - 모든 카드/그리드 레이아웃 모바일 최적화
   - 테이블 가로 스크롤 보장
   - 폼, 필터, 사이드바 모바일 최적화
   ═══════════════════════════════════════════════════════════ */

/* ── 태블릿/모바일 공통 (≤ 1024px) ── */
@media (max-width: 1024px) {
  /* 300px 이상 minmax 그리드 → 2열로 제한 */
  [style*="minmax(300"] { grid-template-columns: repeat(2, 1fr) !important; }
  [style*="minmax(350"] { grid-template-columns: repeat(2, 1fr) !important; }
  [style*="minmax(380"] { grid-template-columns: repeat(2, 1fr) !important; }
  [style*="minmax(400"] { grid-template-columns: 1fr 1fr !important; }
  [style*="minmax(600"] { grid-template-columns: 1fr !important; }
}

/* ── 모바일 (≤ 768px) ── */
@media (max-width: 768px) {

  /* === 모든 큰 카드 그리드 → 1열 === */
  .schedule-grid,
  .work-grid,
  .card-grid,
  .doc-grid,
  .doc-list,
  .project-grid,
  .failure-grid,
  .inspection-grid,
  .license-grid,
  .training-grid,
  .leave-grid,
  .employee-grid,
  .list-grid,
  .item-grid,
  .quick-info,
  .info-grid {
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }

  /* inline-style 큰 minmax 그리드도 처리 */
  [style*="minmax(300"] { grid-template-columns: 1fr !important; }
  [style*="minmax(350"] { grid-template-columns: 1fr !important; }
  [style*="minmax(380"] { grid-template-columns: 1fr !important; }
  [style*="minmax(400"] { grid-template-columns: 1fr !important; }
  [style*="minmax(600"] { grid-template-columns: 1fr !important; }

  /* === 폼 행 → 세로 배치 === */
  .form-row {
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }

  /* === 테이블 전체 가로 스크롤 보장 === */
  .table-container,
  .table-wrap,
  .table-responsive,
  .tbl-wrap {
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
    max-width: 100% !important;
    border-radius: var(--r, 12px) !important;
  }

  /* 래퍼 없는 테이블도 처리 */
  .container table:not(.form-table):not(.print-table),
  .content table:not(.form-table):not(.print-table),
  .main-wrap table:not(.form-table):not(.print-table) {
    display: block !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }

  /* === 사이드바 숨김 (개별 페이지용) === */
  .monitoring-sidebar,
  .side-panel:not(.active),
  .left-panel:not(.active) {
    width: 100% !important;
    max-height: 220px !important;
    border-right: none !important;
    border-bottom: 1px solid var(--border) !important;
  }

  /* === quick-info / 상세 정보 섹션 === */
  .quick-info,
  .info-grid,
  .detail-info,
  .detail-columns {
    display: block !important;
    padding: 14px !important;
  }

  /* === 달력 이벤트 아이템 (유지보수/장애 달력) === */
  .event-item,
  .cal-event,
  .maintenance-event,
  .failure-event {
    font-size: .65rem !important;
    padding: 1px 4px !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
  }

  /* === 카드 내부 버튼 그룹 === */
  .btn-group-card,
  .card-actions,
  .action-buttons {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 5px !important;
  }

  .btn-group-card .btn-action,
  .card-actions a,
  .card-actions button {
    text-align: center !important;
    justify-content: center !important;
    font-size: .72rem !important;
    padding: 7px 4px !important;
  }

  /* === 필터 섹션 전체 스택 === */
  .filter-section,
  .filter-bar,
  .search-bar,
  .search-section {
    flex-direction: column !important;
    gap: 8px !important;
  }

  .filter-group {
    width: 100% !important;
    min-width: 0 !important;
    flex: none !important;
  }

  .filter-select,
  .filter-input,
  .filter-group select,
  .filter-group input {
    width: 100% !important;
    min-width: 0 !important;
  }

  .btn-filter {
    width: 100% !important;
    justify-content: center !important;
    align-self: auto !important;
  }

  /* === 장비 카드 버튼 1줄 처리 === */
  .btn-group-card {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 4px !important;
  }

  /* === 통계 카드 수치 크기 조정 === */
  .stat-number,
  .stat-value,
  .stat-val {
    font-size: 1.5rem !important;
  }

  /* === 페이지네이션 === */
  .pagination,
  .pager {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    gap: 4px !important;
    padding: 12px 0 !important;
  }

  /* === 섹션 헤더 (제목 + 버튼 행) === */
  .sec-hd,
  .section-header,
  .page-header-bar {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 10px !important;
  }

  /* === FAB 버튼 위치 조정 === */
  .quick-actions,
  .fab-container {
    bottom: 16px !important;
    right: 16px !important;
  }

  .fab-button,
  .fab-main {
    width: 50px !important;
    height: 50px !important;
    font-size: 1.2rem !important;
  }
}

/* ── 소형 모바일 (≤ 480px) ── */
@media (max-width: 480px) {
  /* === 컨테이너 여백 최소화 === */
  .container {
    padding-left: 10px !important;
    padding-right: 10px !important;
  }

  /* === 카드 패딩 줄임 === */
  .equipment-card,
  .schedule-card,
  .failure-card,
  .employee-card,
  .doc-card,
  .card {
    padding: 14px 12px !important;
  }

  /* === 버튼 그룹 카드 → 세로 배치 === */
  .btn-group-card {
    flex-direction: column !important;
  }

  .btn-group-card .btn-action {
    width: 100% !important;
  }

  /* === 달력 요일 헤더 === */
  .calendar-header-day,
  .day-header {
    font-size: .6rem !important;
    padding: 4px 1px !important;
  }

  /* === 달력 숫자 === */
  .day-number,
  .date-num {
    font-size: .72rem !important;
  }

  /* === 모달 전체 폭 === */
  .modal-content,
  .modal-box,
  .modal {
    width: 98vw !important;
    max-width: 98vw !important;
    margin: 5px auto !important;
    border-radius: 10px !important;
  }

  /* === 장비 이름 크기 === */
  .equipment-name {
    font-size: 15px !important;
  }

  /* === 일정 제목 크기 === */
  .schedule-title,
  .failure-title {
    font-size: 15px !important;
  }

  /* === 입력 폼 iOS zoom 방지 (16px 이상) === */
  input[type=text],
  input[type=number],
  input[type=email],
  input[type=date],
  input[type=time],
  input[type=password],
  input[type=search],
  select,
  textarea {
    font-size: 16px !important;
  }

  /* === 통계 카드 2열 유지 === */
  .stats-section,
  .stat-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 8px !important;
  }
}

/* ── 가로 방향 (landscape) 소형 화면 ── */
@media (max-height: 500px) and (orientation: landscape) {
  .nav,
  .header {
    height: 44px !important;
    min-height: 44px !important;
  }

  .container {
    padding-top: calc(44px + 10px) !important;
  }

  .main-wrap {
    padding-top: calc(44px + 12px) !important;
  }
}


/* ═══════════════════════════════════════════════════════════
   ADDITIONAL PAGE-SPECIFIC MOBILE FIXES
   ═══════════════════════════════════════════════════════════ */

/* ── Chart.js 반응형 (failure_statistics 등) ── */
@media (max-width: 768px) {
  .chart-container {
    position: relative !important;
    height: 220px !important;
    width: 100% !important;
  }

  canvas {
    max-width: 100% !important;
  }

  /* Bootstrap 컨테이너 모바일 패딩 */
  .container-fluid {
    padding-left: 10px !important;
    padding-right: 10px !important;
  }

  /* Bootstrap row/col 모바일 간격 */
  .row {
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  .col-md-4, .col-md-6, .col-md-8, .col-md-3, .col-md-9 {
    padding-left: 6px !important;
    padding-right: 6px !important;
  }

  /* 점검표 폼 (doc_inspection_form) - 인쇄용 테이블 가로 스크롤 */
  .form-page,
  .inspection-form,
  [class*="form-wrap"],
  [class*="print-wrap"] {
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }

  /* 인쇄용 테이블은 min-width 보장하고 스크롤 */
  .print-table,
  table.inspection-table,
  .doc-table {
    min-width: 600px !important;
    display: table !important;
  }

  /* RAG/챗봇 페이지 */
  .chat-wrap,
  .messages-wrap {
    padding: 0 10px !important;
  }

  /* 작업 이력 (maintenance_work_list 등) */
  .work-card,
  .work-item {
    padding: 14px !important;
  }

  /* 장비 상세 보기 (equipment_form) */
  .equipment-detail,
  .equipment-info-wrap {
    padding: 14px !important;
  }

  /* 인원 카드 (employee_list) */
  .employee-grid {
    grid-template-columns: 1fr !important;
  }

  /* 달력 더보기 표시 */
  .more-events,
  .more-count {
    font-size: .6rem !important;
    padding: 1px 3px !important;
  }

  /* 관리자 대시보드 */
  .manager-stats,
  .dashboard-stats {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

@media (max-width: 480px) {
  /* 차트 높이 줄임 */
  .chart-container {
    height: 180px !important;
  }

  /* 인쇄 폼은 더 작게 */
  .form-page {
    padding: 8px !important;
  }

  /* 주소 및 정보 표시 줄임 */
  .address-full,
  .long-text {
    font-size: .72rem !important;
    line-height: 1.4 !important;
  }
}


/* ============================================================
   UNIFIED BUTTON SYSTEM v2
   fams.bicorn.co.kr 전체 버튼 디자인 통일
   ============================================================ */

/* ── 공통 버튼 베이스 ── */
.btn,
button:not([class*="phoenix"]):not([class*="bootstrap"]) {
  font-family: 'Noto Sans KR', sans-serif !important;
  font-weight: 600 !important;
  border-radius: var(--r-sm, 8px) !important;
  transition: all .2s !important;
  cursor: pointer !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 5px !important;
  line-height: 1.3 !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  -webkit-tap-highlight-color: transparent !important;
}

button:active,
.btn:active {
  transform: scale(.97) !important;
}

/* ── 크기 변형 ── */
.btn-sm {
  padding: 4px 10px !important;
  font-size: .74rem !important;
  min-height: 28px !important;
  border-radius: 6px !important;
}

/* ── Primary (주요 액션 - 저장/제출) ── */
.btn-primary,
button[type="submit"]:not(.btn-sm):not(.btn-white) {
  background: linear-gradient(135deg, var(--accent, #e85d04), var(--accent2, #ff8c42)) !important;
  border: none !important;
  color: #fff !important;
  padding: 8px 18px !important;
  min-height: 36px !important;
  box-shadow: 0 3px 12px rgba(232,93,4,.35) !important;
}
.btn-primary:hover,
button[type="submit"]:not(.btn-sm):not(.btn-white):hover {
  filter: brightness(1.1) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 5px 16px rgba(232,93,4,.45) !important;
}

/* ── Blue/Info (신규 추가/조회) ── */
.btn-blue,
.btn-new,
.btn-view {
  background: linear-gradient(135deg, #1a3a6e, var(--blue2, #4facfe)) !important;
  border: none !important;
  color: #fff !important;
  padding: 8px 16px !important;
  min-height: 36px !important;
  box-shadow: 0 3px 10px rgba(79,172,254,.25) !important;
}
.btn-blue:hover,
.btn-new:hover,
.btn-view:hover {
  filter: brightness(1.1) !important;
  transform: translateY(-1px) !important;
}

/* ── Success/Green ── */
.btn-success,
.btn-green,
.btn-inspect {
  background: linear-gradient(135deg, #059669, #10b981) !important;
  border: none !important;
  color: #fff !important;
  padding: 8px 16px !important;
  min-height: 36px !important;
  box-shadow: 0 3px 10px rgba(16,185,129,.25) !important;
}
.btn-success:hover,
.btn-green:hover,
.btn-inspect:hover {
  filter: brightness(1.1) !important;
  transform: translateY(-1px) !important;
}

/* ── Warning/Yellow ── */
.btn-warning,
.btn-yellow,
.btn-edit {
  background: linear-gradient(135deg, #b45309, #f59e0b) !important;
  border: none !important;
  color: #fff !important;
  padding: 8px 16px !important;
  min-height: 36px !important;
  box-shadow: 0 3px 10px rgba(245,158,11,.25) !important;
}
.btn-warning:hover,
.btn-yellow:hover,
.btn-edit:hover {
  filter: brightness(1.1) !important;
  transform: translateY(-1px) !important;
}

/* ── Danger/Delete ── */
.btn-danger,
.btn-red,
.btn-delete {
  background: linear-gradient(135deg, #b91c1c, #ef4444) !important;
  border: none !important;
  color: #fff !important;
  padding: 8px 16px !important;
  min-height: 36px !important;
  box-shadow: 0 3px 10px rgba(239,68,68,.25) !important;
}
.btn-danger:hover,
.btn-red:hover,
.btn-delete:hover {
  filter: brightness(1.1) !important;
  transform: translateY(-1px) !important;
}

/* ── QR 버튼 ── */
.btn-qr {
  background: linear-gradient(135deg, #0e7490, #06b6d4) !important;
  border: none !important;
  color: #fff !important;
  padding: 8px 16px !important;
  min-height: 36px !important;
  box-shadow: 0 3px 10px rgba(6,182,212,.25) !important;
}
.btn-qr:hover {
  filter: brightness(1.1) !important;
  transform: translateY(-1px) !important;
}

/* ── Ghost / Secondary (내비게이션, 취소, 목록이동) ── */
.btn-white,
.btn-secondary,
.btn-ghost,
.btn-history,
.btn-back,
.btn-clear,
.btn-main,
.btn-map,
.btn-filter,
.btn-nav,
.btn-today {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 5px !important;
  text-decoration: none !important;
  font-family: 'Noto Sans KR', sans-serif !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  white-space: nowrap !important;
  border-radius: var(--r-sm, 8px) !important;
  background: var(--surface2, #141e2e) !important;
  border: 1px solid var(--border2, rgba(255,255,255,.12)) !important;
  color: var(--text-m, #94a3b8) !important;
  padding: 7px 14px !important;
  min-height: 34px !important;
  transition: all .2s !important;
  box-sizing: border-box !important;
}
.btn-white:hover,
.btn-secondary:hover,
.btn-ghost:hover,
.btn-history:hover,
.btn-back:hover,
.btn-clear:hover,
.btn-main:hover,
.btn-map:hover,
.btn-filter:hover,
.btn-nav:hover,
.btn-today:hover {
  background: rgba(255,255,255,.1) !important;
  border-color: rgba(255,255,255,.22) !important;
  color: var(--text, #f0f4f8) !important;
  transform: translateY(-1px) !important;
}

/* ── 메인 이동 버튼 (inline color:red 호환) ── */
.btn-white[style*="color:red"],
.btn[style*="color:red"],
button[style*="color:red"] {
  background: rgba(232,93,4,.12) !important;
  border-color: rgba(232,93,4,.3) !important;
  color: var(--accent2, #ff8c42) !important;
}
.btn-white[style*="color:red"]:hover,
.btn[style*="color:red"]:hover,
button[style*="color:red"]:hover {
  background: rgba(232,93,4,.22) !important;
  border-color: rgba(232,93,4,.5) !important;
}

/* ── Login 버튼 ── */
.btn-login {
  background: linear-gradient(135deg, var(--accent, #e85d04), var(--accent2, #ff8c42)) !important;
  border: none !important;
  color: #fff !important;
  width: 100% !important;
  height: 52px !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  letter-spacing: .5px !important;
  box-shadow: 0 4px 16px rgba(232,93,4,.4) !important;
}
.btn-login:hover {
  filter: brightness(1.1) !important;
  box-shadow: 0 6px 20px rgba(232,93,4,.5) !important;
}

/* ── 카드 내부 액션 버튼 그룹 ── */
.btn-group-card {
  display: flex !important;
  gap: 5px !important;
  flex-wrap: wrap !important;
}

.btn-action {
  flex: 1 !important;
  min-width: 65px !important;
  padding: 7px 6px !important;
  border: none !important;
  border-radius: 6px !important;
  font-size: 11.5px !important;
  font-weight: 600 !important;
  font-family: 'Noto Sans KR', sans-serif !important;
  cursor: pointer !important;
  transition: all .2s !important;
  text-align: center !important;
  min-height: 32px !important;
}

/* ── FAB (Floating Action Button) 통일 ── */
.fab-button,
.quick-actions button {
  border: none !important;
  border-radius: 50% !important;
  cursor: pointer !important;
  transition: all .25s !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-shadow: 0 4px 16px rgba(0,0,0,.45) !important;
  font-size: 22px !important;
  width: 54px !important;
  height: 54px !important;
}
.fab-button:hover {
  transform: scale(1.1) !important;
  box-shadow: 0 6px 22px rgba(0,0,0,.55) !important;
}

.fab-schedule { background: linear-gradient(135deg, #4facfe, #1e3c72) !important; color: #fff !important; }
.fab-work     { background: linear-gradient(135deg, #f093fb, #f5576c) !important; color: #fff !important; }
.fab-failure  { background: linear-gradient(135deg, #e85d04, #ff6b1a) !important; color: #fff !important; }
.fab-list     { background: var(--surface2) !important; border: 1px solid var(--border2) !important; color: var(--text-m) !important; }

/* ── 헤더 전용 버튼 그룹 (btn-hd) ── */
.btn-hd,
.btn-hd-group .btn,
.btn-hd-group button {
  background: var(--surface2) !important;
  border: 1px solid var(--border2) !important;
  color: var(--text-m) !important;
  padding: 6px 13px !important;
  min-height: 32px !important;
  font-size: .78rem !important;
  border-radius: var(--r-sm) !important;
}
.btn-hd:hover,
.btn-hd-group .btn:hover,
.btn-hd-group button:hover {
  background: rgba(255,255,255,.1) !important;
  color: var(--text) !important;
}

/* ── disabled 상태 공통 ── */
button:disabled,
.btn:disabled,
button[disabled],
.btn[disabled] {
  opacity: .38 !important;
  cursor: not-allowed !important;
  transform: none !important;
  box-shadow: none !important;
  filter: none !important;
}

/* ── 모바일 버튼 크기 보정 ── */
@media (max-width: 768px) {
  .btn-action {
    min-width: 55px !important;
    padding: 6px 4px !important;
    font-size: 10.5px !important;
  }
  .fab-button {
    width: 48px !important;
    height: 48px !important;
    font-size: 19px !important;
  }
  .btn-primary,
  button[type="submit"]:not(.btn-sm):not(.btn-white) {
    min-height: 42px !important;
  }
}


/* ============================================================
   CARD ACTION BUTTON COMPACT OVERRIDE
   .btn-action 안에서는 색상만 상속, 크기는 카드에 맞게 고정
   ============================================================ */
.btn-group-card .btn-action,
.card-actions .btn-action {
  flex: 1 !important;
  min-width: 60px !important;
  max-width: none !important;
  padding: 7px 4px !important;
  min-height: 30px !important;
  font-size: 11.5px !important;
  font-weight: 600 !important;
  font-family: 'Noto Sans KR', sans-serif !important;
  border-radius: 6px !important;
  border: none !important;
  cursor: pointer !important;
  text-align: center !important;
  white-space: nowrap !important;
  transition: all .2s !important;
  box-shadow: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* 카드 버튼 hover: subtle brightness */
.btn-group-card .btn-action:hover,
.card-actions .btn-action:hover {
  filter: brightness(1.12) !important;
  transform: translateY(-1px) !important;
}
.btn-group-card .btn-action:active,
.card-actions .btn-action:active {
  transform: scale(.96) !important;
  filter: brightness(.95) !important;
}

/* 카드 버튼 색상은 그대로 상속 (gradient 적용) */
.btn-group-card .btn-action.btn-qr     { background: linear-gradient(135deg,#0e7490,#06b6d4) !important; color:#fff !important; }
.btn-group-card .btn-action.btn-inspect { background: linear-gradient(135deg,#059669,#10b981) !important; color:#fff !important; }
.btn-group-card .btn-action.btn-edit    { background: linear-gradient(135deg,#92400e,#f59e0b) !important; color:#fff !important; }
.btn-group-card .btn-action.btn-history { background: var(--surface2,#141e2e) !important; border:1px solid var(--border2,rgba(255,255,255,.12)) !important; color:var(--text-m,#94a3b8) !important; }
.btn-group-card .btn-action.btn-delete  { background: linear-gradient(135deg,#991b1b,#ef4444) !important; color:#fff !important; }

/* homepage_management의 btn-visit/copy/password/detail 도 통일 */
.card-actions .btn-action.btn-visit    { background: linear-gradient(135deg,#1a3a6e,#4facfe) !important; color:#fff !important; }
.card-actions .btn-action.btn-copy     { background: var(--surface2,#141e2e) !important; border:1px solid var(--border2) !important; color:var(--text-m) !important; }
.card-actions .btn-action.btn-password { background: linear-gradient(135deg,#92400e,#f59e0b) !important; color:#fff !important; }
.card-actions .btn-action.btn-detail   { background: linear-gradient(135deg,#1a3a6e,#4facfe) !important; color:#fff !important; }

@media (max-width: 480px) {
  .btn-group-card .btn-action,
  .card-actions .btn-action {
    min-width: 50px !important;
    padding: 6px 3px !important;
    font-size: 10.5px !important;
    min-height: 28px !important;
  }
}
