/* ─────────────────────────────────────────────────────────────────────────────
   GlobalTech Unified Design System
   Bootstrap 5.3 loaded via CDN in layout — this file adds custom variables,
   component overrides, and shared utilities.
───────────────────────────────────────────────────────────────────────────── */

/* ── CSS Variables ───────────────────────────────────────────────────────── */
:root {
  --gt-primary:       #1a73e8;
  --gt-primary-dark:  #1557b0;
  --gt-primary-light: #e8f0fe;
  --gt-secondary:     #5f6368;
  --gt-success:       #34a853;
  --gt-warning:       #fbbc04;
  --gt-danger:        #ea4335;
  --gt-info:          #00bcd4;

  --gt-bg:            #f1f3f4;
  --gt-surface:       #ffffff;
  --gt-border:        #dadce0;
  --gt-text:          #202124;
  --gt-text-muted:    #5f6368;

  --gt-sidebar-width: 260px;
  --gt-sidebar-bg:    #202124;
  --gt-sidebar-text:  #bdc1c6;
  --gt-sidebar-hover: #303134;
  --gt-sidebar-active:#1a73e8;
  --gt-topbar-height: 60px;

  --gt-radius:   10px;
  --gt-radius-lg:16px;
  --gt-shadow:   0 2px 8px rgba(0,0,0,.10);
  --gt-shadow-lg:0 8px 24px rgba(0,0,0,.14);
  --gt-transition: .2s ease;
}

/* ── Base ────────────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

body {
  font-family: 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  background: var(--gt-bg);
  color: var(--gt-text);
  margin: 0;
  min-height: 100vh;
}

a { color: var(--gt-primary); text-decoration: none; }
a:hover { color: var(--gt-primary-dark); }

/* ── Bootstrap overrides ─────────────────────────────────────────────────── */
.btn-primary {
  background-color: var(--gt-primary);
  border-color: var(--gt-primary);
}
.btn-primary:hover, .btn-primary:focus {
  background-color: var(--gt-primary-dark);
  border-color: var(--gt-primary-dark);
}
.badge.bg-primary { background-color: var(--gt-primary) !important; }

/* ── Cards ───────────────────────────────────────────────────────────────── */
.gt-card {
  background: var(--gt-surface);
  border-radius: var(--gt-radius-lg);
  box-shadow: var(--gt-shadow);
  border: 1px solid var(--gt-border);
  padding: 20px;
  transition: box-shadow var(--gt-transition);
}
.gt-card:hover { box-shadow: var(--gt-shadow-lg); }

.gt-card-header {
  font-size: .75rem;
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--gt-text-muted);
  margin-bottom: 12px;
}

/* ── Module cards (dashboard home) ──────────────────────────────────────── */
.module-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 20px;
}

.module-card {
  background: var(--gt-surface);
  border-radius: var(--gt-radius-lg);
  box-shadow: var(--gt-shadow);
  border: 1px solid var(--gt-border);
  padding: 22px 20px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  transition: transform var(--gt-transition), box-shadow var(--gt-transition);
  text-decoration: none;
  color: var(--gt-text);
}
.module-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--gt-shadow-lg);
  color: var(--gt-text);
}

.module-card .mc-icon {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
  color: #fff;
  flex-shrink: 0;
}

.module-card .mc-title {
  font-weight: 600;
  font-size: 1rem;
}
.module-card .mc-desc {
  font-size: .83rem;
  color: var(--gt-text-muted);
  line-height: 1.4;
}
.module-card .mc-badge {
  font-size: .72rem;
  padding: 3px 8px;
  border-radius: 20px;
  align-self: flex-start;
}

/* ── Stat widgets ────────────────────────────────────────────────────────── */
.stat-card {
  background: var(--gt-surface);
  border-radius: var(--gt-radius-lg);
  box-shadow: var(--gt-shadow);
  padding: 20px;
  display: flex;
  align-items: center;
  gap: 16px;
}
.stat-card .stat-icon {
  width: 52px;
  height: 52px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  color: #fff;
  flex-shrink: 0;
}
.stat-card .stat-value {
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1;
}
.stat-card .stat-label {
  font-size: .8rem;
  color: var(--gt-text-muted);
  margin-top: 4px;
}

/* ── Forms ───────────────────────────────────────────────────────────────── */
.form-control, .form-select {
  border-radius: 8px;
  border: 1.5px solid var(--gt-border);
  transition: border-color var(--gt-transition), box-shadow var(--gt-transition);
}
.form-control:focus, .form-select:focus {
  border-color: var(--gt-primary);
  box-shadow: 0 0 0 3px rgba(26,115,232,.18);
}

/* ── Tables ──────────────────────────────────────────────────────────────── */
.gt-table {
  background: var(--gt-surface);
  border-radius: var(--gt-radius-lg);
  overflow: hidden;
  box-shadow: var(--gt-shadow);
}
.gt-table thead th {
  background: var(--gt-bg);
  border-bottom: 2px solid var(--gt-border);
  font-size: .78rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--gt-text-muted);
  padding: 12px 16px;
}
.gt-table td { padding: 12px 16px; vertical-align: middle; }

/* ── Alerts / flash messages ─────────────────────────────────────────────── */
.gt-alert {
  padding: 12px 16px;
  border-radius: 8px;
  font-size: .9rem;
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 16px;
}
.gt-alert-success { background: #e6f4ea; color: #1e7e34; border-left: 4px solid var(--gt-success); }
.gt-alert-error   { background: #fce8e6; color: #c5221f; border-left: 4px solid var(--gt-danger);  }
.gt-alert-warning { background: #fef7e0; color: #986f00; border-left: 4px solid var(--gt-warning); }
.gt-alert-info    { background: #e3f2fd; color: #0277bd; border-left: 4px solid var(--gt-info);    }

/* ── Loading spinner ─────────────────────────────────────────────────────── */
.gt-spinner-overlay {
  position: fixed;
  inset: 0;
  background: rgba(255,255,255,.7);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  backdrop-filter: blur(2px);
}

/* ── Utility ─────────────────────────────────────────────────────────────── */
.text-primary-gt { color: var(--gt-primary) !important; }
.bg-primary-gt   { background-color: var(--gt-primary) !important; }
.rounded-gt      { border-radius: var(--gt-radius) !important; }
.shadow-gt       { box-shadow: var(--gt-shadow) !important; }

/* Section headers */
.section-title {
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--gt-text-muted);
  margin: 24px 0 12px;
}

/* ── Responsive ──────────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  .module-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 480px) {
  .module-grid { grid-template-columns: 1fr; }
}
