/* ============================================
   Gobotix PMS - Style (Repairslab Design)
   ============================================ */

/* ===== Theme Colors ===== */
:root{
  --bg:#e0e7ff;
  --card:#ffffff;
  --card2:#f8fafc;
  --border:#c7d2fe;
  --text:#1e293b;
  --muted:#64748b;
  --primary:#667eea;
  --primary-hover:#5568d3;
  --success:#10b981;
  --warning:#f59e0b;
  --danger:#ef4444;
  /* PMS status aliases */
  --status-active:#667eea;
  --status-completed:#10b981;
  --status-pending:#f59e0b;
  --status-cancelled:#ef4444;
  --bamboo-green:#10b981;
  --wood-accent:#667eea;
  --shadow:0 4px 6px -1px rgba(102,126,234,.12), 0 2px 4px -1px rgba(102,126,234,.08);
  --shadow-lg:0 10px 15px -3px rgba(102,126,234,.15), 0 4px 6px -2px rgba(102,126,234,.08);
  --shadow-xl:0 20px 25px -5px rgba(102,126,234,.18), 0 10px 10px -5px rgba(102,126,234,.08);
  --gradient-primary:linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  --gradient-success:linear-gradient(135deg, #0ea5e9 0%, #06b6d4 100%);
  --gradient-warm:linear-gradient(135deg, #f093fb 0%, #f5576c 100%);
  --gradient-bg:linear-gradient(135deg, #e0e7ff 0%, #f5f3ff 50%, #ddd6fe 100%);
}

/* ===== Animations ===== */
@keyframes fadeIn { from{opacity:0} to{opacity:1} }
@keyframes slideInLeft { from{opacity:0;transform:translateX(-40px)} to{opacity:1;transform:translateX(0)} }
@keyframes slideInRight { from{opacity:0;transform:translateX(40px)} to{opacity:1;transform:translateX(0)} }
@keyframes slideDown { from{opacity:0;transform:translateY(-30px)} to{opacity:1;transform:translateY(0)} }
@keyframes scaleIn { from{opacity:0;transform:scale(0.98)} to{opacity:1;transform:scale(1)} }
@keyframes shimmer { 0%{background-position:-1000px 0} 100%{background-position:1000px 0} }
@keyframes spin { to{transform:rotate(360deg)} }
@keyframes pulse { 0%,100%{transform:scale(1)} 50%{transform:scale(1.1)} }
@keyframes pageLoad { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }
@keyframes bellRing { 0%,100%{transform:rotate(0deg)} 25%{transform:rotate(15deg)} 75%{transform:rotate(-15deg)} }

/* ===== Base ===== */
*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  font-family:-apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  background:var(--gradient-bg);
  color:var(--text);
  line-height:1.6;
  overflow-x:hidden;
  min-height:100vh;
  animation:pageLoad 0.6s cubic-bezier(0.4,0,0.2,1);
}
a{ color:inherit; text-decoration:none; transition:all 0.3s ease; }
.wrap{ max-width:1200px; margin:0 auto; }
.muted{ color:var(--muted); font-size:13px; }

/* ===== Layout ===== */
.layout{
  display:flex;
  min-height:100vh;
  align-items:stretch;
  background:var(--bg);
}
/* PMS alias */
.layout-container{ display:flex; min-height:100vh; align-items:stretch; background:var(--bg); }

.sidebar{
  width:240px;
  min-width:240px;
  flex:0 0 240px;
  background:linear-gradient(180deg,#ffffff 0%,#faf8ff 100%);
  border-right:1px solid var(--border);
  padding:16px 12px;
  position:sticky;
  top:0;
  height:100vh;
  overflow:hidden;
  box-shadow:var(--shadow-lg);
  animation:slideInLeft 0.8s ease;
  display:flex;
  flex-direction:column;
}

.main{
  flex:1;
  padding:24px;
  min-width:0;
  animation:fadeIn 0.8s ease;
  background:transparent;
}
/* PMS alias */
.main-content{ flex:1; padding:24px; min-width:0; animation:fadeIn 0.8s ease; }

/* ===== Sidebar Logo ===== */
.logo{
  background:var(--gradient-primary);
  border:0;
  border-radius:12px;
  padding:14px 16px;
  margin-bottom:16px;
  box-shadow:var(--shadow-lg);
  position:relative;
  overflow:hidden;
}
.logo::before{
  content:'';
  position:absolute;
  top:-50%; right:-50%;
  width:200%; height:200%;
  background:radial-gradient(circle, rgba(255,255,255,0.1) 0%, transparent 70%);
}
.logo b{ display:block; font-size:15px; line-height:1.2; color:#fff; font-weight:700; position:relative; z-index:1; }
.logo .muted{ font-size:11px; margin-top:4px; color:rgba(255,255,255,0.85); position:relative; z-index:1; }

/* PMS sidebar-header alias */
.sidebar-header{ background:var(--gradient-primary); border-radius:12px; padding:14px 16px; margin-bottom:16px; }
.sidebar-logo{ height:32px; width:auto; display:block; margin-bottom:6px; filter:brightness(0) invert(1); }
.sidebar-title{ font-size:14px; font-weight:700; color:#fff; }

/* ===== Sidebar Nav ===== */
.nav{
  display:flex;
  flex-direction:column;
  gap:4px;
  margin-top:8px;
  flex:1;
  overflow-y:auto;
  overflow-x:hidden;
  min-height:0;
  scrollbar-width:none;
  -ms-overflow-style:none;
  padding-left:2px;
}
.nav::-webkit-scrollbar{ display:none; }
.nav a{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:8px 10px;
  border:1px solid var(--border);
  border-left:3px solid transparent;
  border-radius:8px;
  background:var(--card);
  transition:all 0.2s ease;
  color:var(--text);
}
.nav a:hover{
  border-color:var(--primary);
  border-left-color:var(--primary);
  box-shadow:var(--shadow);
  background:color-mix(in srgb, var(--primary) 5%, var(--card) 95%);
}
.nav a.active{
  border-color:var(--primary);
  border-left:3px solid var(--primary);
  box-shadow:var(--shadow-lg);
  background:linear-gradient(135deg, color-mix(in srgb, var(--primary) 10%, transparent 90%), color-mix(in srgb, var(--primary) 5%, transparent 95%));
}
.nav .left{ display:flex; align-items:center; gap:10px; }
.nav .icon{ width:20px; text-align:center; font-size:16px; }
.nav .title{ font-weight:500; font-size:13px; }
.nav a.active .title{ font-weight:700; }
.nav .desc{ font-size:11px; color:var(--muted); margin-top:1px; }
.nav .chev{ color:var(--muted); font-size:14px; }

/* PMS sidebar-menu alias */
.sidebar-menu{ list-style:none; display:flex; flex-direction:column; gap:4px; flex:1; overflow-y:auto; scrollbar-width:none; padding-left:2px; }
.sidebar-menu::-webkit-scrollbar{ display:none; }
.sidebar-menu li a{
  display:flex; align-items:center; justify-content:space-between;
  padding:9px 12px; border:1px solid var(--border); border-left:3px solid transparent;
  border-radius:8px; background:var(--card); transition:all 0.2s ease; color:var(--text);
  gap:10px; font-weight:500; font-size:13px; text-decoration:none;
}
.sidebar-menu li a:hover{ border-color:var(--primary); border-left-color:var(--primary); box-shadow:var(--shadow); background:color-mix(in srgb, var(--primary) 5%, var(--card) 95%); }
.sidebar-menu li a.active{ border-color:var(--primary); border-left:3px solid var(--primary); box-shadow:var(--shadow-lg); font-weight:700; background:linear-gradient(135deg, color-mix(in srgb, var(--primary) 10%, transparent 90%), color-mix(in srgb, var(--primary) 5%, transparent 95%)); }
.sidebar-menu li a i{ width:18px; text-align:center; font-size:14px; color:var(--primary); }

/* ===== Sidebar Footer ===== */
.sideFooter{
  flex-shrink:0;
  margin-top:8px;
  font-size:11px;
  color:var(--muted);
  border-top:1px solid var(--border);
  padding-top:10px;
}
/* PMS sidebar-footer alias */
.sidebar-footer{ flex-shrink:0; margin-top:8px; border-top:1px solid var(--border); padding-top:12px; display:flex; flex-direction:column; gap:8px; }
.user-info{ display:flex; align-items:center; gap:10px; padding:8px; background:var(--card2); border-radius:8px; border:1px solid var(--border); }
.user-info i{ font-size:24px; color:var(--primary); }
.user-details .user-name{ font-weight:700; font-size:13px; color:var(--text); }
.user-details .user-role{ font-size:11px; color:var(--muted); }
.lang-toggle{ display:flex; align-items:center; gap:8px; padding:6px 8px; }
.lang-toggle a{ font-size:12px; font-weight:600; padding:4px 10px; border-radius:6px; border:1px solid var(--border); color:var(--text); background:var(--card); }
.lang-toggle a.active{ background:var(--gradient-primary); color:#fff; border-color:transparent; }
.sidebar-actions .btn{ width:100%; justify-content:center; }

/* ===== Top Bar ===== */
.top{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:16px;
  margin-bottom:24px;
  animation:fadeIn 0.6s ease-out 0.2s both;
  flex-wrap:wrap;
}
.top-actions{ display:flex; align-items:center; gap:16px; margin-left:auto; }

/* ===== Cards ===== */
.card{
  background:linear-gradient(135deg,#ffffff 0%,#fefbff 100%);
  border:1px solid var(--border);
  border-radius:14px;
  padding:18px;
  margin-bottom:16px;
  box-shadow:var(--shadow-lg);
  transition:all 0.3s ease;
  animation:fadeIn 0.8s ease;
  position:relative;
  overflow:hidden;
}
.card::before{
  content:'';
  position:absolute; top:0; left:0; right:0;
  height:2px;
  background:var(--gradient-primary);
  transform:scaleX(0);
  transition:transform 0.4s ease;
}
.card:hover{ box-shadow:0 8px 24px rgba(102,126,234,0.18); transform:translateY(-2px); border-color:color-mix(in srgb, var(--primary) 30%, var(--border) 70%); }
.card:hover::before{ transform:scaleX(1); }

/* PMS card-header alias */
.card-header{
  font-size:15px; font-weight:700; color:var(--text);
  border-bottom:2px solid var(--border);
  padding-bottom:12px; margin-bottom:16px;
  display:flex; align-items:center; gap:8px;
}
.card-header i{ color:var(--primary); }

/* PMS mb-4 utility */
.mb-4{ margin-bottom:24px; }
.mt-3{ margin-top:16px; }

/* ===== Grid ===== */
.grid{ display:grid; grid-template-columns:repeat(12,1fr); gap:16px; animation:fadeIn 0.6s ease-out 0.3s both; }
.kpi{ grid-column:span 3; }
.wide{ grid-column:span 12; }
/* PMS grid aliases */
.grid-2{ display:grid; grid-template-columns:repeat(2,1fr); gap:16px; }
.grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
.grid-4{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.gap-2{ gap:16px; }

/* ===== Typography ===== */
h2{
  margin:0 0 14px;
  font-size:16px; font-weight:700; color:var(--text);
  position:relative; padding-bottom:12px;
}
h2::after{
  content:''; position:absolute; left:0; bottom:0;
  width:40px; height:3px;
  background:var(--gradient-primary); border-radius:2px;
}
.num{
  font-size:36px; font-weight:800; margin-top:8px;
  background:var(--gradient-primary);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}

/* ===== Stat Cards (PMS) ===== */
.stat-card{ text-align:center; }
.stat-card-value{
  font-size:36px; font-weight:800;
  background:var(--gradient-primary);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.stat-card-label{ font-size:12px; color:var(--muted); text-transform:uppercase; letter-spacing:0.5px; margin-top:4px; }
.stat-card-icon{ font-size:28px; margin-bottom:8px; opacity:0.7; }
.kpi .card{ text-align:center; }
.kpi .card:nth-child(4n+1){ border-top:3px solid var(--primary); }
.kpi .card:nth-child(4n+2){ border-top:3px solid var(--success); }
.kpi .card:nth-child(4n+3){ border-top:3px solid var(--warning); }
.kpi .card:nth-child(4n+4){ border-top:3px solid var(--danger); }

/* ===== Forms ===== */
label{ display:block; font-size:13px; font-weight:600; color:var(--text); margin:12px 0 6px; }
/* PMS form-label alias */
.form-label{ display:block; font-size:13px; font-weight:600; color:var(--text); margin:0 0 6px; }
.form-label.required::after{ content:' *'; color:var(--danger); }
/* PMS form-group alias */
.form-group{ margin-bottom:16px; }

input,select,textarea,
.form-input,.form-select,.form-textarea{
  width:100%; padding:10px 14px;
  border:2px solid var(--border); border-radius:10px;
  font-size:14px; background:var(--card); color:var(--text);
  transition:all 0.2s ease; font-family:inherit;
}
input:focus,select:focus,textarea:focus,
.form-input:focus,.form-select:focus,.form-textarea:focus{
  outline:none;
  border-color:var(--primary);
  box-shadow:0 0 0 3px color-mix(in srgb, var(--primary) 12%, transparent 88%);
}
input:hover,select:hover,textarea:hover,
.form-input:hover,.form-select:hover,.form-textarea:hover{
  border-color:color-mix(in srgb, var(--primary) 40%, var(--border) 60%);
}
input[type="checkbox"],input[type="radio"]{ width:auto; }
textarea,.form-textarea{ min-height:100px; resize:vertical; line-height:1.6; }
::placeholder{ color:var(--muted); opacity:0.7; }

.row{ display:grid; grid-template-columns:repeat(12,1fr); gap:14px; width:100%; }
.col6{ grid-column:span 6; min-width:0; }
.col12{ grid-column:span 12; min-width:0; }
.actions{ display:flex; gap:12px; flex-wrap:wrap; margin-top:20px; align-items:center; }

/* ===== Buttons ===== */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:6px;
  padding:10px 18px; border-radius:10px; text-decoration:none; border:0;
  cursor:pointer; font-size:14px; font-weight:600;
  transition:all 0.25s ease; position:relative; overflow:hidden;
  box-shadow:var(--shadow);
}
.btn:hover{ transform:translateY(-1px); box-shadow:0 4px 12px rgba(102,126,234,0.25); }
.btn:active{ transform:translateY(0); }

/* Primary (purple gradient) */
.btn-primary,.btnPrimary{
  background:var(--gradient-primary); color:#fff; box-shadow:var(--shadow-lg);
}
.btn-primary:hover,.btnPrimary:hover{ box-shadow:0 6px 16px rgba(102,126,234,0.3); transform:translateY(-1px); color:#fff; }

/* Secondary (ghost) */
.btn-secondary,.btnGhost{
  background:var(--card); color:var(--text); border:2px solid var(--border);
}
.btn-secondary:hover,.btnGhost:hover{ border-color:var(--primary); background:color-mix(in srgb, var(--primary) 8%, var(--card) 92%); transform:translateY(-2px); }

/* Success */
.btn-success{
  background:linear-gradient(135deg, #10b981 0%, #0ca678 100%); color:#fff;
  box-shadow:0 4px 12px rgba(16,185,129,0.3);
}
.btn-success:hover{ box-shadow:0 6px 20px rgba(16,185,129,0.4); transform:translateY(-2px); color:#fff; }

/* Danger */
.btn-danger,.btnDanger{
  background:linear-gradient(135deg, var(--danger) 0%, color-mix(in srgb, var(--danger) 85%, #000 15%) 100%);
  color:#fff; box-shadow:0 4px 12px rgba(239,68,68,0.3);
}
.btn-danger:hover,.btnDanger:hover{ box-shadow:0 6px 20px rgba(239,68,68,0.4); transform:translateY(-2px); color:#fff; }

/* Info */
.btn-info{
  background:linear-gradient(135deg, #0ea5e9 0%, #06b6d4 100%); color:#fff;
  box-shadow:0 4px 12px rgba(14,165,233,0.3);
}
.btn-info:hover{ box-shadow:0 6px 20px rgba(14,165,233,0.4); transform:translateY(-2px); color:#fff; }

/* Warning */
.btn-warning{
  background:linear-gradient(135deg, var(--warning) 0%, #d97706 100%); color:#fff;
  box-shadow:0 4px 12px rgba(245,158,11,0.3);
}
.btn-warning:hover{ box-shadow:0 6px 20px rgba(245,158,11,0.4); transform:translateY(-2px); color:#fff; }

/* Small */
.btn-sm{ padding:6px 14px; font-size:12px; }

/* ===== Alerts / Messages ===== */
.alert,.success,.error{
  padding:14px 18px; border-radius:12px; margin:12px 0;
  font-weight:500; display:flex; align-items:flex-start; gap:12px; line-height:1.5;
}
.alert-success,.success{
  background:linear-gradient(135deg, #d1fae5 0%, #a7f3d0 100%);
  border:2px solid var(--success); color:#065f46;
  animation:slideInRight 0.5s ease-out;
  box-shadow:0 4px 12px rgba(16,185,129,0.2);
}
.alert-error,.error{
  background:linear-gradient(135deg, #fee2e2 0%, #fecaca 100%);
  border:2px solid var(--danger); color:#991b1b;
  animation:slideInRight 0.5s ease-out;
  box-shadow:0 4px 12px rgba(239,68,68,0.2);
}
.alert-info{
  background:linear-gradient(135deg, #dbeafe 0%, #bfdbfe 100%);
  border:2px solid #3b82f6; color:#1e40af;
}
.alert-warning{
  background:linear-gradient(135deg, #fef3c7 0%, #fde68a 100%);
  border:2px solid var(--warning); color:#92400e;
}

/* ===== Tables ===== */
table{
  width:100%; border-collapse:separate; border-spacing:0;
  animation:fadeIn 0.6s ease-out;
}
.table{ width:100%; border-collapse:separate; border-spacing:0; }
thead{ background:var(--gradient-primary); color:#fff !important; box-shadow:0 4px 12px rgba(102,126,234,0.25); }
th{
  padding:12px 14px; text-align:left;
  font-size:12px; font-weight:700; text-transform:uppercase;
  letter-spacing:0.4px; border-bottom:2px solid var(--primary);
  color:#fff !important; background:transparent;
}
th:first-child{ border-top-left-radius:10px; }
th:last-child{ border-top-right-radius:10px; }
tbody tr{
  border-bottom:1px solid var(--border);
  transition:all 0.3s ease; background:#ffffff;
}
tbody tr:hover{
  background:linear-gradient(135deg, #f0f4ff 0%, #faf6ff 100%);
  transform:scale(1.005);
  box-shadow:0 2px 12px rgba(102,126,234,0.12);
}
td{ padding:11px 14px; font-size:13px; color:var(--text); }
td:last-child{ white-space:nowrap; }
tbody tr:last-child{ border-bottom:0; }
tbody tr:last-child td:first-child{ border-bottom-left-radius:12px; }
tbody tr:last-child td:last-child{ border-bottom-right-radius:12px; }

/* PMS table-sm alias */
.table-sm th,.table-sm td{ padding:8px 12px; font-size:12px; }

/* ===== Table Wrapper ===== */
.table-wrapper{
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  border-radius:12px;
  margin-bottom:16px;
}

/* ===== Badges ===== */
.badge{
  display:inline-flex; align-items:center; gap:6px;
  padding:5px 12px; border-radius:999px;
  font-size:12px; font-weight:600; text-transform:uppercase; letter-spacing:0.4px;
  transition:all 0.3s ease;
}
.badge::before{ content:''; width:7px; height:7px; border-radius:50%; animation:pulse 2s ease-in-out infinite; }

.badge-success,.badge-completed{
  background:color-mix(in srgb, var(--success) 15%, transparent 85%);
  color:var(--success); border:1px solid var(--success);
}
.badge-success::before,.badge-completed::before{ background:var(--success); }

.badge-warning,.badge-pending{
  background:color-mix(in srgb, var(--warning) 15%, transparent 85%);
  color:var(--warning); border:1px solid var(--warning);
}
.badge-warning::before,.badge-pending::before{ background:var(--warning); }

.badge-danger,.badge-cancelled{
  background:color-mix(in srgb, var(--danger) 15%, transparent 85%);
  color:var(--danger); border:1px solid var(--danger);
}
.badge-danger::before,.badge-cancelled::before{ background:var(--danger); }

.badge-primary,.badge-active{
  background:color-mix(in srgb, var(--primary) 15%, transparent 85%);
  color:var(--primary); border:1px solid var(--primary);
}
.badge-primary::before,.badge-active::before{ background:var(--primary); }

.badge-secondary{
  background:color-mix(in srgb, var(--muted) 15%, transparent 85%);
  color:var(--muted); border:1px solid var(--muted);
}
.badge-secondary::before{ background:var(--muted); }

.badge-info{
  background:color-mix(in srgb, #0ea5e9 15%, transparent 85%);
  color:#0ea5e9; border:1px solid #0ea5e9;
}
.badge-info::before{ background:#0ea5e9; }

/* ===== Page Header ===== */
.page-header,.content-header{
  background:var(--gradient-primary);
  border-radius:16px; padding:22px 28px; margin-bottom:24px;
  color:#fff; box-shadow:var(--shadow-xl);
  position:relative; overflow:hidden;
  animation:slideDown 0.8s ease;
  display:flex; align-items:center; justify-content:space-between;
  flex-wrap:wrap; gap:12px;
}
.page-header::before{
  content:''; position:absolute; top:-50%; right:-20%;
  width:300px; height:300px;
  background:radial-gradient(circle, rgba(255,255,255,0.1) 0%, transparent 70%);
  border-radius:50%;
}
.page-header-title,.content-title{
  font-size:22px; font-weight:700; margin:0;
  display:flex; align-items:center; gap:10px;
  text-shadow:0 2px 10px rgba(0,0,0,0.2); color:#fff;
}
.page-header-subtitle{ font-size:14px; margin-top:8px; opacity:0.9; }
.page-header-actions,.content-actions{
  display:flex; gap:10px; flex-wrap:wrap; align-items:center;
  position:relative; z-index:2;
}
.page-header-actions .btn,.content-actions .btn{
  background:rgba(255,255,255,0.2); color:#fff;
  border:2px solid rgba(255,255,255,0.4);
  backdrop-filter:blur(10px);
}
.page-header-actions .btn:hover,.content-actions .btn:hover{
  background:rgba(255,255,255,0.3);
  border-color:rgba(255,255,255,0.6);
  transform:translateY(-2px);
}
.content-actions .btn-primary{ background:#fff; color:var(--primary); border:2px solid #fff; }
.content-actions .btn-primary:hover{ background:rgba(255,255,255,0.95); transform:translateY(-2px); }

/* ===== Login Page ===== */
.login-container{
  display:flex; justify-content:center; align-items:center;
  min-height:100vh; padding:20px;
  background:var(--gradient-bg);
}
.login-card{
  background:#fff; border-radius:20px;
  padding:40px; max-width:420px; width:100%;
  box-shadow:var(--shadow-xl); text-align:center;
  animation:scaleIn 0.5s ease-out;
  border:1px solid var(--border);
  position:relative; overflow:hidden;
}
.login-card::before{
  content:''; position:absolute; top:0; left:0; right:0; height:4px;
  background:var(--gradient-primary);
}
.login-logo{ max-width:120px; margin:0 auto 16px; display:block; }
.login-title{ font-size:22px; font-weight:700; color:var(--text); margin-bottom:4px; }
.login-subtitle{ font-size:14px; color:var(--muted); margin-bottom:28px; }

/* ===== Status Color Utilities ===== */
.text-success{ color:var(--success); }
.text-danger{ color:var(--danger); }
.text-warning{ color:var(--warning); }
.text-primary{ color:var(--primary); }
.text-muted{ color:var(--muted); }

/* ===== Loading ===== */
.loading{
  display:inline-block; width:20px; height:20px;
  border:3px solid var(--border); border-top-color:var(--primary);
  border-radius:50%; animation:spin 0.6s linear infinite;
}

/* ===== Scrollbar ===== */
::-webkit-scrollbar{ width:8px; height:8px; }
::-webkit-scrollbar-track{ background:var(--card2); border-radius:10px; }
::-webkit-scrollbar-thumb{ background:var(--gradient-primary); border-radius:10px; }

/* ===== Divider ===== */
.divider{ height:1px; background:linear-gradient(90deg, transparent 0%, var(--border) 50%, transparent 100%); margin:20px 0; }

/* ===== Empty State ===== */
.empty-state{ text-align:center; padding:60px 20px; color:var(--muted); }
.empty-state i,.empty-state-icon{ font-size:56px; opacity:0.3; margin-bottom:16px; display:block; }
.empty-state p{ font-size:16px; font-weight:600; margin-bottom:8px; }

/* ===== Focus Visible ===== */
button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{
  outline:3px solid var(--primary); outline-offset:2px;
}

/* ===== Reduce Motion ===== */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{ animation-duration:0.01ms !important; transition-duration:0.01ms !important; }
}

/* ===== Print ===== */
@media print{
  .sidebar,#menuBtn,.sideOverlay,.sidebar-toggle,.sidebar-overlay,.btn,.actions,.page-header-actions,.content-actions{ display:none !important; }
  .main,.main-content{ padding:0; }
  .card{ box-shadow:none; border:1px solid #ddd; }
}

/* ===== Mobile Button ===== */
#menuBtn{
  display:none; align-items:center; justify-content:center; gap:8px;
  padding:10px 16px; background:var(--card); border:2px solid var(--border);
  border-radius:12px; cursor:pointer; font-weight:600; font-size:14px; color:var(--text);
  transition:all 0.3s ease;
}
#menuBtn:hover{ border-color:var(--primary); background:color-mix(in srgb, var(--primary) 8%, var(--card) 92%); }

/* ===== Side Overlay (Mobile) ===== */
.sideOverlay,.sidebar-overlay{
  display:none; position:fixed; inset:0;
  background:rgba(0,0,0,0.55); backdrop-filter:blur(4px);
  z-index:999; animation:fadeIn 0.3s ease;
}
.sideOverlay.show,.sidebar-overlay.show,.sidebar-overlay.active{ display:block; }

/* ===== Responsive ===== */
@media (max-width:980px){
  #menuBtn{ display:inline-flex; }
  .kpi{ grid-column:span 6; }
  .col6{ grid-column:span 12 !important; }
}

@media (max-width:720px){
  #menuBtn{ display:inline-flex; }
  .sidebar{
    position:fixed; top:0; left:-100%;
    width:280px; min-width:280px; height:100vh;
    z-index:1000; transition:left 0.3s cubic-bezier(0.4,0,0.2,1);
    box-shadow:var(--shadow-xl);
  }
  .sidebar.open,.sidebar.active{ left:0; }
  .main,.main-content{ padding:16px 12px; }
  .kpi{ grid-column:span 12; }
  .grid-2,.grid-3,.grid-4{ grid-template-columns:1fr; }
  .col6{ grid-column:span 12 !important; }
  .card{ padding:16px; border-radius:12px; }
  .top{ position:sticky; top:0; background:var(--bg); z-index:998; padding:10px 0; margin-bottom:16px; }
  .page-header,.content-header{ padding:18px 16px; border-radius:12px; }
  .page-header-title,.content-title{ font-size:18px; }
  h2{ font-size:15px; }
  .num,.stat-card-value{ font-size:26px; }
  input,select,textarea,.form-input,.form-select,.form-textarea{ font-size:16px; }
  .btn-sm{ min-height:36px; }
  .table{ display:block; overflow-x:auto; white-space:nowrap; }
  table{ display:block; overflow-x:auto; -webkit-overflow-scrolling:touch; white-space:nowrap; }
  thead{ display:table; width:100%; table-layout:auto; }
  tbody{ display:table; width:100%; table-layout:auto; }
  th,td{ padding:9px 8px; font-size:12px; min-width:80px; }
  .table-wrapper{ margin:0 -16px 16px; border-radius:0; }
  .actions{ flex-direction:column; }
  .actions .btn{ width:100%; justify-content:center; }
  table .btn,td .btn{ width:auto !important; min-width:auto; font-size:12px; padding:7px 10px; }
}

@media (max-width:480px){
  .main,.main-content{ padding:10px 8px; }
  .card{ padding:12px; }
  .page-header,.content-header{ padding:14px 12px; }
  h2{ font-size:14px; }
  .num,.stat-card-value{ font-size:22px; }
}

@media (hover:none) and (pointer:coarse){
  .btn{ min-height:46px; padding:12px 20px; }
  input,select,textarea,.form-input,.form-select,.form-textarea{ min-height:46px; font-size:16px; }
  .nav a,.sidebar-menu li a{ min-height:50px; }
}

/* ===== PMS Utility Classes ===== */
.card-body{ padding:20px; }
.flex-between{ display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:8px; }
.ml-2{ margin-left:8px; }
.mr-2{ margin-right:8px; }
.mb-3{ margin-bottom:16px; }
.mb-4{ margin-bottom:24px; }
.mt-3{ margin-top:16px; }
.mt-4{ margin-top:24px; }
.text-center{ text-align:center; }
.text-right{ text-align:right; }
.w-100{ width:100%; }
.gap-2{ gap:16px; }

/* ===== Stat Cards - Proper Card Style ===== */
.stat-card{
  background:linear-gradient(135deg,#ffffff 0%,#fefbff 100%);
  border:1px solid var(--border);
  border-radius:14px;
  padding:20px 16px;
  text-align:center;
  box-shadow:var(--shadow-lg);
  transition:all 0.3s ease;
  animation:fadeIn 0.8s ease;
  position:relative;
  overflow:hidden;
}
.stat-card::before{
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:var(--gradient-primary); transform:scaleX(0); transition:transform 0.4s ease;
}
.stat-card:hover{ box-shadow:0 8px 24px rgba(102,126,234,0.18); transform:translateY(-3px); }
.stat-card:hover::before{ transform:scaleX(1); }
.stat-card-value{
  font-size:38px; font-weight:800; margin:8px 0 4px;
  background:var(--gradient-primary);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  line-height:1.1;
}
.stat-card-label{
  font-size:11px; color:var(--muted); text-transform:uppercase;
  letter-spacing:0.6px; font-weight:600; margin-top:4px;
}
.stat-card-icon{ font-size:24px; margin-bottom:6px; opacity:0.6; }

/* Stat card color variants */
.stat-card.active .stat-card-value{ background:var(--primary); -webkit-background-clip:text; background-clip:text; }
.stat-card.completed .stat-card-value{ background:var(--success); -webkit-background-clip:text; background-clip:text; }
.stat-card.pending .stat-card-value{ background:var(--warning); -webkit-background-clip:text; background-clip:text; }
.stat-card.cancelled .stat-card-value{ background:var(--danger); -webkit-background-clip:text; background-clip:text; }
.stat-card.active{ border-top:3px solid var(--primary); }
.stat-card.completed{ border-top:3px solid var(--success); }
.stat-card.pending{ border-top:3px solid var(--warning); }
.stat-card.cancelled{ border-top:3px solid var(--danger); }
