/* MAPTOO DESIGN SYSTEM 2.0 */
/* --------------------------------------------
   1. KOLORY (odświeżone, spójne, profesjonalne)
--------------------------------------------- */

:root {
  --maptoo-navy: #0B1539;
  --maptoo-navy-soft: #0F1A44;

  --maptoo-blue: #3E63D3;
  --maptoo-blue-hover: #3556BB;
  --maptoo-blue-active: #2E4AA5;

  --maptoo-light-blue: #7DA1FF;
  --maptoo-light-blue-soft: #E6ECFF;

  --maptoo-gray: #6E7DA5;
  --maptoo-gray-light: #D9DFEB;

  --maptoo-bg: #F5F7FA;
  --maptoo-surface: #FFFFFF;
  --maptoo-surface-subtle: #F0F3FA;

  --maptoo-success: #22B573;
  --maptoo-error: #E7473C;
  --maptoo-warning: #F5A623;
  --maptoo-info: #3E63D3;

  --type-wz: #3E63D3;
  --type-mpzp: #1E8D55;
  --type-zpi: #E58A1F;
  --type-pog: #8A35AF;

  --maptoo-border: #D9DFEB;

  --font-main: 'DM Sans', Arial, sans-serif;

  --h1-size: 30px;
  --h2-size: 24px;
  --h3-size: 18px;

  --body-size: 15.5px;
  --small-size: 13px;
  --micro-size: 11.5px;

  --line-height: 1.5;

  --sp-4: 4px;
  --sp-8: 8px;
  --sp-12: 12px;
  --sp-16: 16px;
  --sp-24: 24px;
  --sp-32: 32px;

  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 12px;
  --radius-xl: 20px;
  --radius-pill: 100px;

  --shadow-sm: 0 2px 4px rgba(0,0,0,0.06);
  --shadow-md: 0 4px 10px rgba(0,0,0,0.08);
  --shadow-lg: 0 10px 24px rgba(0,0,0,0.12);

  --nav-height: 56px;
  --sidebar-width: 200px;

  /* Text colors from TSX */
  --text-primary: #1A1E2E;
  --text-secondary: #7A8BB5;
  --border-color: #E5E8F0;
}

body {
  background: var(--maptoo-bg);
  font-size: 13.5px;
  font-family: var(--font-main);
  line-height: var(--line-height);
  color: var(--text-primary);
}

body.maptoo {
  font-size: 13.5px;
  color: var(--text-primary);
  background: var(--maptoo-bg);
}

h1 { font-size: var(--h1-size); font-weight: 700; }
h2 { font-size: var(--h2-size); font-weight: 650; }
h3 { font-size: var(--h3-size); font-weight: 600; }

.small { font-size: var(--small-size); }
.micro { font-size: var(--micro-size); }

/* BUTTONS */
.maptoo-btn {
  border: none;
  cursor: pointer;
  padding: var(--sp-8) var(--sp-16);
  border-radius: var(--radius-sm);
  font-weight: 500;
  transition: 0.15s ease;
  font-size: var(--body-size);
}

.maptoo-btn-primary {
  background: var(--maptoo-blue);
  color: white;
}
.maptoo-btn-primary:hover { background: var(--maptoo-blue-hover); }
.maptoo-btn-primary:active { background: var(--maptoo-blue-active); }

.maptoo-btn-secondary {
  background: white;
  border: 2px solid var(--maptoo-navy);
  color: var(--maptoo-navy);
}
.maptoo-btn-secondary:hover { background: #F0F3FA; }

.maptoo-btn-ghost {
  background: transparent;
  color: var(--maptoo-blue);
}
.maptoo-btn-ghost:hover {
  background: rgba(62,99,211,0.08);
}

/* INPUTS */
.maptoo-input,
.maptoo-select,
.maptoo-textarea {
  border: 1px solid var(--maptoo-gray-light);
  border-radius: var(--radius-sm);
  padding: 0 var(--sp-12);
  height: 42px;
  font-size: var(--body-size);
  background: white;
  transition: 0.15s;
}
.maptoo-input:focus,
.maptoo-select:focus,
.maptoo-textarea:focus {
  outline: 2px solid rgba(62, 99, 211, 0.35);
  border-color: var(--maptoo-blue);
}
.maptoo-textarea {
  height: auto;
  min-height: 120px;
  padding: var(--sp-12);
  resize: vertical;
}

/* CARDS */
.maptoo-card {
  background: var(--maptoo-surface);
  border: 1px solid rgba(0,0,0,0.05);
  border-radius: var(--radius-md);
  padding: 20px;
  box-shadow: var(--shadow-sm);
  transition: 0.15s;
}
.maptoo-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

/* TABLE */
.maptoo-table {
  width: 100%;
  border-collapse: collapse;
  background: white;
}
.maptoo-table th {
  background: var(--maptoo-surface-subtle);
  padding: var(--sp-12);
  font-size: var(--body-size);
  font-weight: 600;
  border-bottom: 2px solid var(--maptoo-gray-light);
}
.maptoo-table td {
  padding: var(--sp-12);
  border-bottom: 1px solid var(--maptoo-gray-light);
  height: 46px;
}
.maptoo-table tr:hover td {
  background: #EBEEF7;
}

/* MODAL */
.maptoo-modal {
  background: white;
  border-radius: var(--radius-lg);
  max-width: 560px;
  padding: var(--sp-24);
  margin: 0 auto;
  box-shadow: var(--shadow-lg);
}
.maptoo-modal-header {
  padding-bottom: 12px;
  margin-bottom: 16px;
  font-size: var(--h3-size);
  font-weight: 600;
  border-bottom: 1px solid var(--maptoo-gray-light);
}

/* BADGES */
.maptoo-badge {
  display: inline-block;
  padding: 0 10px;
  height: 22px;
  line-height: 22px;
  font-size: 12.5px;
  font-weight: 600;
  border-radius: var(--radius-pill);
}
.badge-success {
  background: rgba(34,181,115,0.12);
  color: var(--maptoo-success);
  border: 1px solid rgba(34,181,115,0.35);
}
.badge-info {
  background: rgba(62,99,211,0.12);
  color: var(--maptoo-info);
  border: 1px solid rgba(62,99,211,0.35);
}
.badge-warning {
  background: rgba(245,166,35,0.12);
  color: var(--maptoo-warning);
  border: 1px solid rgba(245,166,35,0.35);
}
.badge-error {
  background: rgba(231,71,60,0.12);
  color: var(--maptoo-error);
  border: 1px solid rgba(231,71,60,0.35);
}

/* IKONY */
.maptoo-icon {
  margin-right: var(--sp-8);
  opacity: 0.85;
  font-size: 1.1em;
}

/* ============================================
   TSX REDESIGN OVERRIDES
   ============================================ */

/* HEADER — base sizing only, colors set per-panel */
.maptoo-nav {
  height: 56px;
}

/* SIDEBAR — 200px, smaller text */
.maptoo-sidebar {
  width: 200px;
  padding: 12px 0;
  border-right: 1px solid var(--border-color);
}

.maptoo-sidebar-link {
  font-size: 14px;
  padding: 8px 16px;
  gap: 10px;
  border-radius: 7px;
}

.maptoo-sidebar-link.active {
  background: #EBF0FF;
  color: #4F6CE0;
}

/* LAYOUT — adjust for new sidebar */
.maptoo-layout {
  min-height: calc(100vh - 56px);
}

.maptoo-main {
  padding: 20px;
}

/* BUTTONS — 7px radius */
.maptoo-btn {
  border-radius: 7px;
  font-size: 13px;
  padding: 8px 16px;
}

.maptoo-btn-sm {
  padding: 6px 12px;
  font-size: 12.5px;
}

/* CARDS — 9px radius, subtle shadow */
.maptoo-card {
  border-radius: 9px;
  border: 1px solid var(--border-color);
  box-shadow: 0 1px 3px rgba(15,27,68,0.04);
  padding: 14px;
}

.maptoo-card:hover {
  box-shadow: 0 2px 8px rgba(15,27,68,0.08);
  transform: none;
}

/* INPUTS — updated */
.maptoo-input,
.maptoo-select {
  height: 38px;
  font-size: 13px;
  border-color: var(--border-color);
  border-radius: 7px;
}

/* BADGES — 20px radius (pill) */
.maptoo-badge {
  border-radius: 20px;
  font-size: 11px;
  height: 20px;
  line-height: 20px;
  padding: 0 8px;
}

/* STATUS BADGES (TSX colors) */
.status-draft,
.status-do-zrobienia { background: #F0F2F8; color: #7A8BB5; }
.status-submitted,
.status-w-trakcie { background: #EBF0FF; color: #4F6CE0; }
.status-reviewing { background: #FFF3E0; color: #E67E22; }
.status-feedback { background: #FFF8E1; color: #F9A825; }
.status-approved,
.status-zakonczony { background: #E8F8EF; color: #1B7A3D; }
.status-published { background: #E8F8EF; color: #0D6B2E; }
.status-rejected { background: #FDECEA; color: #E74C3C; }

/* TYPE BADGES (TSX colors) */
.type-wz { background: #EBF0FF; color: #4F6CE0; }
.type-mpzp { background: #E8F8EF; color: #1B7A3D; }
.type-zpi { background: #FFF3E0; color: #E67E22; }
.type-pog { background: #F3E5F5; color: #7B1FA2; }

/* TYPE TABS (TSX pill style) */
.type-tabs {
  background: rgba(15,27,68,0.04);
  border-radius: 9px;
  padding: 3px;
}

.type-tab {
  border-radius: 7px;
  font-size: 13px;
  padding: 8px 14px;
}

.type-tab.active {
  box-shadow: 0 1px 3px rgba(15,27,68,0.08);
}

/* STATUS TABS (TSX style) */
.status-tab {
  font-size: 13px;
  padding: 8px 16px;
}

.tab-count {
  font-size: 10px;
  min-width: 18px;
  height: 18px;
  border-radius: 9px;
}

/* PROJECT LIST ITEMS (TSX card style) */
.project-list-item {
  border: 1px solid var(--border-color);
  border-radius: 9px;
  padding: 12px 14px;
  gap: 12px;
}

.project-list-item:hover {
  border-color: #4F6CE0;
  box-shadow: 0 2px 6px rgba(79,108,224,0.08);
}

.project-list-item-icon {
  width: 36px;
  height: 36px;
  border-radius: 7px;
  font-size: 14px;
}

.project-list-item-title {
  font-size: 14px;
}

.project-list-item-meta {
  font-size: 12px;
  color: var(--text-secondary);
}

/* PROGRESS BAR (new from TSX) */
.project-progress-bar {
  height: 4px;
  background: #F0F2F8;
  border-radius: 2px;
  margin-top: 8px;
  overflow: hidden;
}

.project-progress-bar-fill {
  height: 100%;
  border-radius: 2px;
  transition: width 0.3s ease;
}

.project-progress-bar-fill.type-wz { background: #4F6CE0; }
.project-progress-bar-fill.type-mpzp { background: #1B7A3D; }
.project-progress-bar-fill.type-zpi { background: #E67E22; }
.project-progress-bar-fill.type-pog { background: #7B1FA2; }

/* MUNICIPALITY FOLDERS (TSX style) */
.municipality-folder-header {
  border-radius: 9px;
  padding: 8px 14px;
  background: rgba(15,27,68,0.03);
  border: 1px solid var(--border-color);
}

.municipality-folder-name {
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.3px;
}

.municipality-folder-count {
  min-width: 20px;
  height: 20px;
  border-radius: 10px;
  font-size: 11px;
}

/* EDITOR (TSX toolbar) */
.editor-toolbar {
  border-radius: 9px;
  border: 1px solid var(--border-color);
}

.editor-textarea {
  border-radius: 9px;
  font-size: 14px;
  border: 1px solid var(--border-color);
}

/* TABLES (TSX style) */
.maptoo-table th {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.7px;
  color: var(--text-secondary);
  background: var(--maptoo-bg);
  border-bottom: 1px solid var(--border-color);
  padding: 10px 14px;
}

.maptoo-table td {
  font-size: 13px;
  padding: 10px 14px;
  border-bottom: 1px solid var(--border-color);
}

/* REVIEW FEEDBACK BUTTONS (TSX colors) */
.btn-approve {
  background: #27AE60;
  color: white;
  border: none;
  border-radius: 7px;
}

.btn-feedback {
  background: #FFF3E0;
  color: #E67E22;
  border: 1px solid #E67E22;
  border-radius: 7px;
}

.btn-reject {
  background: #FDECEA;
  color: #E74C3C;
  border: 1px solid #E74C3C;
  border-radius: 7px;
}

/* SEARCH INPUT (TSX pill style) */
.search-bar .maptoo-input {
  border-radius: 20px;
  padding-left: 36px;
  background: #F7F8FC;
  border: 1px solid var(--border-color);
}

/* KPI CARDS (Investor/Admin) */
.kpi-cards {
  display: flex;
  gap: 12px;
}

.kpi-card {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 12px;
  background: white;
  border: 1px solid var(--border-color);
  border-radius: 12px;
  padding: 16px;
}

.kpi-card-icon {
  width: 40px;
  height: 40px;
  border-radius: 9px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
}

.kpi-card-value {
  font-size: 22px;
  font-weight: 700;
  color: var(--text-primary);
}

.kpi-card-label {
  font-size: 12px;
  color: var(--text-secondary);
}

/* NOTIFICATION ITEMS (TSX style) */
.notification-item {
  border-left: 3px solid transparent;
  border-radius: 0 7px 7px 0;
}

.notification-item.unread {
  border-left-color: #4F6CE0;
  background: rgba(79,108,224,0.03);
}

/* MODAL (TSX style) */
.maptoo-modal {
  border-radius: 12px;
}

.maptoo-modal-header {
  border-bottom: 1px solid var(--border-color);
}

/* GEOPORTAL OVERRIDES (dark sidebar, compact header) */
.header {
  height: 52px !important;
}

.sidebar {
  background: #1A2140 !important;
}

/* RESPONSIVE TWEAKS */
@media (max-width: 1024px) {
  .kpi-cards { flex-wrap: wrap; }
  .kpi-card { flex: 1 1 calc(50% - 6px); }
}

@media (max-width: 768px) {
  .maptoo-sidebar { width: 0; display: none; }
  .kpi-card { flex: 1 1 100%; }
}
