@charset "UTF-8";

/* node_modules/primeicons/primeicons.css */
@font-face {
  font-family: "primeicons";
  font-display: block;
  src: url("./media/primeicons.eot");
  src:
    url("./media/primeicons.eot?#iefix") format("embedded-opentype"),
    url("./media/primeicons.woff2") format("woff2"),
    url("./media/primeicons.woff") format("woff"),
    url("./media/primeicons.ttf") format("truetype"),
    url("./media/primeicons.svg?#primeicons") format("svg");
  font-weight: normal;
  font-style: normal;
}
.pi {
  font-family: "primeicons";
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  display: inline-block;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.pi:before {
  --webkit-backface-visibility:hidden;
  backface-visibility: hidden;
}
.pi-fw {
  width: 1.28571429em;
  text-align: center;
}
.pi-spin {
  -webkit-animation: fa-spin 2s infinite linear;
  animation: fa-spin 2s infinite linear;
}
@media (prefers-reduced-motion: reduce) {
  .pi-spin {
    -webkit-animation-delay: -1ms;
    animation-delay: -1ms;
    -webkit-animation-duration: 1ms;
    animation-duration: 1ms;
    -webkit-animation-iteration-count: 1;
    animation-iteration-count: 1;
    -webkit-transition-delay: 0s;
    transition-delay: 0s;
    -webkit-transition-duration: 0s;
    transition-duration: 0s;
  }
}
@-webkit-keyframes fa-spin {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(359deg);
    transform: rotate(359deg);
  }
}
@keyframes fa-spin {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(359deg);
    transform: rotate(359deg);
  }
}
.pi-folder-plus:before {
  content: "\ea05";
}
.pi-receipt:before {
  content: "\ea06";
}
.pi-asterisk:before {
  content: "\ea07";
}
.pi-face-smile:before {
  content: "\ea08";
}
.pi-pinterest:before {
  content: "\ea09";
}
.pi-expand:before {
  content: "\ea0a";
}
.pi-pen-to-square:before {
  content: "\ea0b";
}
.pi-wave-pulse:before {
  content: "\ea0c";
}
.pi-turkish-lira:before {
  content: "\ea0d";
}
.pi-spinner-dotted:before {
  content: "\ea0e";
}
.pi-crown:before {
  content: "\ea0f";
}
.pi-pause-circle:before {
  content: "\ea10";
}
.pi-warehouse:before {
  content: "\ea11";
}
.pi-objects-column:before {
  content: "\ea12";
}
.pi-clipboard:before {
  content: "\ea13";
}
.pi-play-circle:before {
  content: "\ea14";
}
.pi-venus:before {
  content: "\ea15";
}
.pi-cart-minus:before {
  content: "\ea16";
}
.pi-file-plus:before {
  content: "\ea17";
}
.pi-microchip:before {
  content: "\ea18";
}
.pi-twitch:before {
  content: "\ea19";
}
.pi-building-columns:before {
  content: "\ea1a";
}
.pi-file-check:before {
  content: "\ea1b";
}
.pi-microchip-ai:before {
  content: "\ea1c";
}
.pi-trophy:before {
  content: "\ea1d";
}
.pi-barcode:before {
  content: "\ea1e";
}
.pi-file-arrow-up:before {
  content: "\ea1f";
}
.pi-mars:before {
  content: "\ea20";
}
.pi-tiktok:before {
  content: "\ea21";
}
.pi-arrow-up-right-and-arrow-down-left-from-center:before {
  content: "\ea22";
}
.pi-ethereum:before {
  content: "\ea23";
}
.pi-list-check:before {
  content: "\ea24";
}
.pi-thumbtack:before {
  content: "\ea25";
}
.pi-arrow-down-left-and-arrow-up-right-to-center:before {
  content: "\ea26";
}
.pi-equals:before {
  content: "\ea27";
}
.pi-lightbulb:before {
  content: "\ea28";
}
.pi-star-half:before {
  content: "\ea29";
}
.pi-address-book:before {
  content: "\ea2a";
}
.pi-chart-scatter:before {
  content: "\ea2b";
}
.pi-indian-rupee:before {
  content: "\ea2c";
}
.pi-star-half-fill:before {
  content: "\ea2d";
}
.pi-cart-arrow-down:before {
  content: "\ea2e";
}
.pi-calendar-clock:before {
  content: "\ea2f";
}
.pi-sort-up-fill:before {
  content: "\ea30";
}
.pi-sparkles:before {
  content: "\ea31";
}
.pi-bullseye:before {
  content: "\ea32";
}
.pi-sort-down-fill:before {
  content: "\ea33";
}
.pi-graduation-cap:before {
  content: "\ea34";
}
.pi-hammer:before {
  content: "\ea35";
}
.pi-bell-slash:before {
  content: "\ea36";
}
.pi-gauge:before {
  content: "\ea37";
}
.pi-shop:before {
  content: "\ea38";
}
.pi-headphones:before {
  content: "\ea39";
}
.pi-eraser:before {
  content: "\ea04";
}
.pi-stopwatch:before {
  content: "\ea01";
}
.pi-verified:before {
  content: "\ea02";
}
.pi-delete-left:before {
  content: "\ea03";
}
.pi-hourglass:before {
  content: "\e9fe";
}
.pi-truck:before {
  content: "\ea00";
}
.pi-wrench:before {
  content: "\e9ff";
}
.pi-microphone:before {
  content: "\e9fa";
}
.pi-megaphone:before {
  content: "\e9fb";
}
.pi-arrow-right-arrow-left:before {
  content: "\e9fc";
}
.pi-bitcoin:before {
  content: "\e9fd";
}
.pi-file-edit:before {
  content: "\e9f6";
}
.pi-language:before {
  content: "\e9f7";
}
.pi-file-export:before {
  content: "\e9f8";
}
.pi-file-import:before {
  content: "\e9f9";
}
.pi-file-word:before {
  content: "\e9f1";
}
.pi-gift:before {
  content: "\e9f2";
}
.pi-cart-plus:before {
  content: "\e9f3";
}
.pi-thumbs-down-fill:before {
  content: "\e9f4";
}
.pi-thumbs-up-fill:before {
  content: "\e9f5";
}
.pi-arrows-alt:before {
  content: "\e9f0";
}
.pi-calculator:before {
  content: "\e9ef";
}
.pi-sort-alt-slash:before {
  content: "\e9ee";
}
.pi-arrows-h:before {
  content: "\e9ec";
}
.pi-arrows-v:before {
  content: "\e9ed";
}
.pi-pound:before {
  content: "\e9eb";
}
.pi-prime:before {
  content: "\e9ea";
}
.pi-chart-pie:before {
  content: "\e9e9";
}
.pi-reddit:before {
  content: "\e9e8";
}
.pi-code:before {
  content: "\e9e7";
}
.pi-sync:before {
  content: "\e9e6";
}
.pi-shopping-bag:before {
  content: "\e9e5";
}
.pi-server:before {
  content: "\e9e4";
}
.pi-database:before {
  content: "\e9e3";
}
.pi-hashtag:before {
  content: "\e9e2";
}
.pi-bookmark-fill:before {
  content: "\e9df";
}
.pi-filter-fill:before {
  content: "\e9e0";
}
.pi-heart-fill:before {
  content: "\e9e1";
}
.pi-flag-fill:before {
  content: "\e9de";
}
.pi-circle:before {
  content: "\e9dc";
}
.pi-circle-fill:before {
  content: "\e9dd";
}
.pi-bolt:before {
  content: "\e9db";
}
.pi-history:before {
  content: "\e9da";
}
.pi-box:before {
  content: "\e9d9";
}
.pi-at:before {
  content: "\e9d8";
}
.pi-arrow-up-right:before {
  content: "\e9d4";
}
.pi-arrow-up-left:before {
  content: "\e9d5";
}
.pi-arrow-down-left:before {
  content: "\e9d6";
}
.pi-arrow-down-right:before {
  content: "\e9d7";
}
.pi-telegram:before {
  content: "\e9d3";
}
.pi-stop-circle:before {
  content: "\e9d2";
}
.pi-stop:before {
  content: "\e9d1";
}
.pi-whatsapp:before {
  content: "\e9d0";
}
.pi-building:before {
  content: "\e9cf";
}
.pi-qrcode:before {
  content: "\e9ce";
}
.pi-car:before {
  content: "\e9cd";
}
.pi-instagram:before {
  content: "\e9cc";
}
.pi-linkedin:before {
  content: "\e9cb";
}
.pi-send:before {
  content: "\e9ca";
}
.pi-slack:before {
  content: "\e9c9";
}
.pi-sun:before {
  content: "\e9c8";
}
.pi-moon:before {
  content: "\e9c7";
}
.pi-vimeo:before {
  content: "\e9c6";
}
.pi-youtube:before {
  content: "\e9c5";
}
.pi-flag:before {
  content: "\e9c4";
}
.pi-wallet:before {
  content: "\e9c3";
}
.pi-map:before {
  content: "\e9c2";
}
.pi-link:before {
  content: "\e9c1";
}
.pi-credit-card:before {
  content: "\e9bf";
}
.pi-discord:before {
  content: "\e9c0";
}
.pi-percentage:before {
  content: "\e9be";
}
.pi-euro:before {
  content: "\e9bd";
}
.pi-book:before {
  content: "\e9ba";
}
.pi-shield:before {
  content: "\e9b9";
}
.pi-paypal:before {
  content: "\e9bb";
}
.pi-amazon:before {
  content: "\e9bc";
}
.pi-phone:before {
  content: "\e9b8";
}
.pi-filter-slash:before {
  content: "\e9b7";
}
.pi-facebook:before {
  content: "\e9b4";
}
.pi-github:before {
  content: "\e9b5";
}
.pi-twitter:before {
  content: "\e9b6";
}
.pi-step-backward-alt:before {
  content: "\e9ac";
}
.pi-step-forward-alt:before {
  content: "\e9ad";
}
.pi-forward:before {
  content: "\e9ae";
}
.pi-backward:before {
  content: "\e9af";
}
.pi-fast-backward:before {
  content: "\e9b0";
}
.pi-fast-forward:before {
  content: "\e9b1";
}
.pi-pause:before {
  content: "\e9b2";
}
.pi-play:before {
  content: "\e9b3";
}
.pi-compass:before {
  content: "\e9ab";
}
.pi-id-card:before {
  content: "\e9aa";
}
.pi-ticket:before {
  content: "\e9a9";
}
.pi-file-o:before {
  content: "\e9a8";
}
.pi-reply:before {
  content: "\e9a7";
}
.pi-directions-alt:before {
  content: "\e9a5";
}
.pi-directions:before {
  content: "\e9a6";
}
.pi-thumbs-up:before {
  content: "\e9a3";
}
.pi-thumbs-down:before {
  content: "\e9a4";
}
.pi-sort-numeric-down-alt:before {
  content: "\e996";
}
.pi-sort-numeric-up-alt:before {
  content: "\e997";
}
.pi-sort-alpha-down-alt:before {
  content: "\e998";
}
.pi-sort-alpha-up-alt:before {
  content: "\e999";
}
.pi-sort-numeric-down:before {
  content: "\e99a";
}
.pi-sort-numeric-up:before {
  content: "\e99b";
}
.pi-sort-alpha-down:before {
  content: "\e99c";
}
.pi-sort-alpha-up:before {
  content: "\e99d";
}
.pi-sort-alt:before {
  content: "\e99e";
}
.pi-sort-amount-up:before {
  content: "\e99f";
}
.pi-sort-amount-down:before {
  content: "\e9a0";
}
.pi-sort-amount-down-alt:before {
  content: "\e9a1";
}
.pi-sort-amount-up-alt:before {
  content: "\e9a2";
}
.pi-palette:before {
  content: "\e995";
}
.pi-undo:before {
  content: "\e994";
}
.pi-desktop:before {
  content: "\e993";
}
.pi-sliders-v:before {
  content: "\e991";
}
.pi-sliders-h:before {
  content: "\e992";
}
.pi-search-plus:before {
  content: "\e98f";
}
.pi-search-minus:before {
  content: "\e990";
}
.pi-file-excel:before {
  content: "\e98e";
}
.pi-file-pdf:before {
  content: "\e98d";
}
.pi-check-square:before {
  content: "\e98c";
}
.pi-chart-line:before {
  content: "\e98b";
}
.pi-user-edit:before {
  content: "\e98a";
}
.pi-exclamation-circle:before {
  content: "\e989";
}
.pi-android:before {
  content: "\e985";
}
.pi-google:before {
  content: "\e986";
}
.pi-apple:before {
  content: "\e987";
}
.pi-microsoft:before {
  content: "\e988";
}
.pi-heart:before {
  content: "\e984";
}
.pi-mobile:before {
  content: "\e982";
}
.pi-tablet:before {
  content: "\e983";
}
.pi-key:before {
  content: "\e981";
}
.pi-shopping-cart:before {
  content: "\e980";
}
.pi-comments:before {
  content: "\e97e";
}
.pi-comment:before {
  content: "\e97f";
}
.pi-briefcase:before {
  content: "\e97d";
}
.pi-bell:before {
  content: "\e97c";
}
.pi-paperclip:before {
  content: "\e97b";
}
.pi-share-alt:before {
  content: "\e97a";
}
.pi-envelope:before {
  content: "\e979";
}
.pi-volume-down:before {
  content: "\e976";
}
.pi-volume-up:before {
  content: "\e977";
}
.pi-volume-off:before {
  content: "\e978";
}
.pi-eject:before {
  content: "\e975";
}
.pi-money-bill:before {
  content: "\e974";
}
.pi-images:before {
  content: "\e973";
}
.pi-image:before {
  content: "\e972";
}
.pi-sign-in:before {
  content: "\e970";
}
.pi-sign-out:before {
  content: "\e971";
}
.pi-wifi:before {
  content: "\e96f";
}
.pi-sitemap:before {
  content: "\e96e";
}
.pi-chart-bar:before {
  content: "\e96d";
}
.pi-camera:before {
  content: "\e96c";
}
.pi-dollar:before {
  content: "\e96b";
}
.pi-lock-open:before {
  content: "\e96a";
}
.pi-table:before {
  content: "\e969";
}
.pi-map-marker:before {
  content: "\e968";
}
.pi-list:before {
  content: "\e967";
}
.pi-eye-slash:before {
  content: "\e965";
}
.pi-eye:before {
  content: "\e966";
}
.pi-folder-open:before {
  content: "\e964";
}
.pi-folder:before {
  content: "\e963";
}
.pi-video:before {
  content: "\e962";
}
.pi-inbox:before {
  content: "\e961";
}
.pi-lock:before {
  content: "\e95f";
}
.pi-unlock:before {
  content: "\e960";
}
.pi-tags:before {
  content: "\e95d";
}
.pi-tag:before {
  content: "\e95e";
}
.pi-power-off:before {
  content: "\e95c";
}
.pi-save:before {
  content: "\e95b";
}
.pi-question-circle:before {
  content: "\e959";
}
.pi-question:before {
  content: "\e95a";
}
.pi-copy:before {
  content: "\e957";
}
.pi-file:before {
  content: "\e958";
}
.pi-clone:before {
  content: "\e955";
}
.pi-calendar-times:before {
  content: "\e952";
}
.pi-calendar-minus:before {
  content: "\e953";
}
.pi-calendar-plus:before {
  content: "\e954";
}
.pi-ellipsis-v:before {
  content: "\e950";
}
.pi-ellipsis-h:before {
  content: "\e951";
}
.pi-bookmark:before {
  content: "\e94e";
}
.pi-globe:before {
  content: "\e94f";
}
.pi-replay:before {
  content: "\e94d";
}
.pi-filter:before {
  content: "\e94c";
}
.pi-print:before {
  content: "\e94b";
}
.pi-align-right:before {
  content: "\e946";
}
.pi-align-left:before {
  content: "\e947";
}
.pi-align-center:before {
  content: "\e948";
}
.pi-align-justify:before {
  content: "\e949";
}
.pi-cog:before {
  content: "\e94a";
}
.pi-cloud-download:before {
  content: "\e943";
}
.pi-cloud-upload:before {
  content: "\e944";
}
.pi-cloud:before {
  content: "\e945";
}
.pi-pencil:before {
  content: "\e942";
}
.pi-users:before {
  content: "\e941";
}
.pi-clock:before {
  content: "\e940";
}
.pi-user-minus:before {
  content: "\e93e";
}
.pi-user-plus:before {
  content: "\e93f";
}
.pi-trash:before {
  content: "\e93d";
}
.pi-external-link:before {
  content: "\e93c";
}
.pi-window-maximize:before {
  content: "\e93b";
}
.pi-window-minimize:before {
  content: "\e93a";
}
.pi-refresh:before {
  content: "\e938";
}
.pi-user:before {
  content: "\e939";
}
.pi-exclamation-triangle:before {
  content: "\e922";
}
.pi-calendar:before {
  content: "\e927";
}
.pi-chevron-circle-left:before {
  content: "\e928";
}
.pi-chevron-circle-down:before {
  content: "\e929";
}
.pi-chevron-circle-right:before {
  content: "\e92a";
}
.pi-chevron-circle-up:before {
  content: "\e92b";
}
.pi-angle-double-down:before {
  content: "\e92c";
}
.pi-angle-double-left:before {
  content: "\e92d";
}
.pi-angle-double-right:before {
  content: "\e92e";
}
.pi-angle-double-up:before {
  content: "\e92f";
}
.pi-angle-down:before {
  content: "\e930";
}
.pi-angle-left:before {
  content: "\e931";
}
.pi-angle-right:before {
  content: "\e932";
}
.pi-angle-up:before {
  content: "\e933";
}
.pi-upload:before {
  content: "\e934";
}
.pi-download:before {
  content: "\e956";
}
.pi-ban:before {
  content: "\e935";
}
.pi-star-fill:before {
  content: "\e936";
}
.pi-star:before {
  content: "\e937";
}
.pi-chevron-left:before {
  content: "\e900";
}
.pi-chevron-right:before {
  content: "\e901";
}
.pi-chevron-down:before {
  content: "\e902";
}
.pi-chevron-up:before {
  content: "\e903";
}
.pi-caret-left:before {
  content: "\e904";
}
.pi-caret-right:before {
  content: "\e905";
}
.pi-caret-down:before {
  content: "\e906";
}
.pi-caret-up:before {
  content: "\e907";
}
.pi-search:before {
  content: "\e908";
}
.pi-check:before {
  content: "\e909";
}
.pi-check-circle:before {
  content: "\e90a";
}
.pi-times:before {
  content: "\e90b";
}
.pi-times-circle:before {
  content: "\e90c";
}
.pi-plus:before {
  content: "\e90d";
}
.pi-plus-circle:before {
  content: "\e90e";
}
.pi-minus:before {
  content: "\e90f";
}
.pi-minus-circle:before {
  content: "\e910";
}
.pi-circle-on:before {
  content: "\e911";
}
.pi-circle-off:before {
  content: "\e912";
}
.pi-sort-down:before {
  content: "\e913";
}
.pi-sort-up:before {
  content: "\e914";
}
.pi-sort:before {
  content: "\e915";
}
.pi-step-backward:before {
  content: "\e916";
}
.pi-step-forward:before {
  content: "\e917";
}
.pi-th-large:before {
  content: "\e918";
}
.pi-arrow-down:before {
  content: "\e919";
}
.pi-arrow-left:before {
  content: "\e91a";
}
.pi-arrow-right:before {
  content: "\e91b";
}
.pi-arrow-up:before {
  content: "\e91c";
}
.pi-bars:before {
  content: "\e91d";
}
.pi-arrow-circle-down:before {
  content: "\e91e";
}
.pi-arrow-circle-left:before {
  content: "\e91f";
}
.pi-arrow-circle-right:before {
  content: "\e920";
}
.pi-arrow-circle-up:before {
  content: "\e921";
}
.pi-info:before {
  content: "\e923";
}
.pi-info-circle:before {
  content: "\e924";
}
.pi-home:before {
  content: "\e925";
}
.pi-spinner:before {
  content: "\e926";
}

/* src/styles.scss */
:root {
  --color-brand: #E8345A;
  --color-brand-light: #FF6B8A;
  --color-brand-dark: #B0204A;
  --color-brand-faint: rgba(232, 52, 90, 0.12);
  --color-bg: #0A0A0A;
  --color-surface: #161616;
  --color-surface-elevated: #1F1F1F;
  --color-divider: #2A2A2A;
  --color-text-primary: #FFFFFF;
  --color-text-secondary: #AAAAAA;
  --color-text-muted: #666666;
  --color-text-disabled: #444444;
  --color-success: #22C55E;
  --color-error: #EF4444;
  --color-warning: #F59E0B;
  --color-info: #3B82F6;
  --color-premium: #8B5CF6;
  --color-human: #10B981;
  --color-avatar: #8B5CF6;
  --color-positive: #22C55E;
  --color-neutral: #3B82F6;
  --color-negative: #EF4444;
  --agent-conversation: #3B82F6;
  --agent-matcher: #F59E0B;
  --agent-enricher: #8B5CF6;
  --agent-police: #EF4444;
  --agent-psychologist: #06B6D4;
  --agent-human-readiness: #10B981;
  --gradient-brand:
    linear-gradient(
      135deg,
      #FF6B8A,
      #E8345A);
  --gradient-card:
    linear-gradient(
      135deg,
      #161616,
      #1F1F1F);
  --gradient-bg:
    linear-gradient(
      180deg,
      #0A0A0A,
      #111111,
      #0A0A0A);
  --bg-sidebar: #0A0A0A;
  --bg-topbar: #161616;
  --bg-page: #0A0A0A;
  --bg-card: #161616;
  --bg-card-hover: #1F1F1F;
  --sidebar-width: 260px;
  --topbar-height: 64px;
  --border-color: #2A2A2A;
  --font-display:
    "Playfair Display",
    Georgia,
    serif;
  --font-body:
    "Inter",
    -apple-system,
    BlinkMacSystemFont,
    "Segoe UI",
    sans-serif;
  --font-family:
    "Inter",
    -apple-system,
    BlinkMacSystemFont,
    "Segoe UI",
    sans-serif;
  --text-xs: 12px;
  --text-sm: 14px;
  --text-base: 16px;
  --text-md: 18px;
  --text-lg: 20px;
  --text-xl: 23px;
  --text-2xl: 26px;
  --text-3xl: 32px;
  --text-4xl: 40px;
  --fw-regular: 400;
  --fw-medium: 500;
  --fw-semibold: 600;
  --fw-bold: 700;
}
.heading-hero {
  font-family: var(--font-display);
  font-size: var(--text-4xl);
  font-weight: var(--fw-bold);
  letter-spacing: -0.5px;
}
.heading-xl {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  font-weight: var(--fw-bold);
  letter-spacing: -0.3px;
}
.heading-lg {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: var(--fw-semibold);
}
.heading-md {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: var(--fw-semibold);
}
.heading-sm {
  font-family: var(--font-body);
  font-size: var(--text-lg);
  font-weight: var(--fw-semibold);
}
.body-lg {
  font-family: var(--font-body);
  font-size: var(--text-md);
  font-weight: var(--fw-regular);
}
.body-md {
  font-family: var(--font-body);
  font-size: var(--text-base);
  font-weight: var(--fw-regular);
}
.body-sm {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--fw-regular);
}
.label-lg {
  font-family: var(--font-body);
  font-size: var(--text-base);
  font-weight: var(--fw-semibold);
  letter-spacing: 0.3px;
}
.label-sm {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: var(--fw-medium);
  letter-spacing: 0.8px;
}
* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}
html,
body {
  height: 100%;
  font-family: var(--font-family);
  background: var(--bg-page);
  color: var(--color-text-primary);
  font-size: 16px;
  line-height: 1.6;
  font-variant-numeric: tabular-nums;
}
.app-layout {
  display: flex;
  height: 100vh;
  overflow: hidden;
}
.app-sidebar {
  width: var(--sidebar-width);
  background: var(--bg-sidebar);
  height: 100vh;
  overflow-y: auto;
  overflow-x: hidden;
  flex-shrink: 0;
  transition: width 0.3s ease;
  z-index: 100;
  border-right: 1px solid var(--color-divider);
}
.app-sidebar.collapsed {
  width: 60px;
}
.app-main {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.app-topbar {
  height: var(--topbar-height);
  background: var(--bg-topbar);
  border-bottom: 1px solid var(--color-divider);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  padding: 0 24px;
  gap: 16px;
  z-index: 50;
}
.app-content {
  flex: 1;
  overflow-y: auto;
  padding: 24px;
  background: var(--bg-page);
}
.kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin-bottom: 24px;
}
.kpi-grid.cols-3 {
  grid-template-columns: repeat(3, 1fr);
}
.kpi-grid.cols-2 {
  grid-template-columns: repeat(2, 1fr);
}
.kpi-card {
  background: var(--bg-card);
  border-radius: 14px;
  padding: 24px;
  border: 1px solid var(--color-divider);
  transition: border-color 0.2s, background 0.2s;
}
.kpi-card:hover {
  border-color: rgba(232, 52, 90, 0.3);
  background: var(--bg-card-hover);
}
.kpi-card .kpi-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
}
.kpi-card .kpi-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--color-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.07em;
}
.kpi-card .kpi-icon {
  width: 44px;
  height: 44px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
}
.kpi-card .kpi-icon.brand {
  background: var(--color-brand-faint);
  color: var(--color-brand);
}
.kpi-card .kpi-icon.blue {
  background: rgba(59, 130, 246, 0.12);
  color: #3B82F6;
}
.kpi-card .kpi-icon.green {
  background: rgba(34, 197, 94, 0.12);
  color: #22C55E;
}
.kpi-card .kpi-icon.yellow {
  background: rgba(245, 158, 11, 0.12);
  color: #F59E0B;
}
.kpi-card .kpi-icon.red {
  background: rgba(239, 68, 68, 0.12);
  color: #EF4444;
}
.kpi-card .kpi-icon.violet {
  background: rgba(139, 92, 246, 0.12);
  color: #8B5CF6;
}
.kpi-card .kpi-icon.emerald {
  background: rgba(16, 185, 129, 0.12);
  color: #10B981;
}
.kpi-card .kpi-value {
  font-size: 34px;
  font-weight: 700;
  font-family: var(--font-body);
  font-variant-numeric: tabular-nums;
  color: var(--color-text-primary);
  line-height: 1;
  margin-bottom: 8px;
}
.kpi-card .kpi-subtitle {
  font-size: 14px;
  color: var(--color-text-muted);
}
.kpi-card .kpi-trend {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 13px;
  font-weight: 600;
  margin-top: 10px;
  padding: 3px 10px;
  border-radius: 20px;
}
.kpi-card .kpi-trend.up {
  background: rgba(34, 197, 94, 0.12);
  color: #22C55E;
}
.kpi-card .kpi-trend.down {
  background: rgba(239, 68, 68, 0.12);
  color: #EF4444;
}
.card {
  background: var(--bg-card);
  border-radius: 14px;
  padding: 28px;
  border: 1px solid var(--color-divider);
  margin-bottom: 24px;
}
.card .card-title {
  font-size: 16px;
  font-weight: 600;
  color: var(--color-text-primary);
  margin-bottom: 20px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--color-divider);
}
.card-grid {
  display: grid;
  gap: 20px;
  margin-bottom: 24px;
}
.card-grid.cols-2 {
  grid-template-columns: repeat(2, 1fr);
}
.card-grid.cols-3 {
  grid-template-columns: repeat(3, 1fr);
}
.card-grid.cols-4 {
  grid-template-columns: repeat(4, 1fr);
}
.card-grid.cols-1-2 {
  grid-template-columns: 1fr 2fr;
}
.card-grid.cols-2-1 {
  grid-template-columns: 2fr 1fr;
}
.page-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 32px;
}
.page-header h1 {
  font-size: 26px;
  font-weight: 700;
  color: var(--color-text-primary);
}
.page-header .page-subtitle {
  font-size: 15px;
  color: var(--color-text-secondary);
  margin-top: 4px;
}
.badge {
  display: inline-flex;
  align-items: center;
  padding: 4px 12px;
  border-radius: 20px;
  font-size: 13px;
  font-weight: 600;
}
.badge.green {
  background: rgba(34, 197, 94, 0.15);
  color: #22C55E;
}
.badge.yellow {
  background: rgba(245, 158, 11, 0.15);
  color: #F59E0B;
}
.badge.red {
  background: rgba(239, 68, 68, 0.15);
  color: #EF4444;
}
.badge.blue {
  background: rgba(59, 130, 246, 0.15);
  color: #3B82F6;
}
.badge.gray {
  background: rgba(255, 255, 255, 0.08);
  color: #AAAAAA;
}
.badge.violet {
  background: rgba(139, 92, 246, 0.15);
  color: #8B5CF6;
}
.badge.orange {
  background: rgba(245, 158, 11, 0.15);
  color: #F59E0B;
}
.badge.emerald {
  background: rgba(16, 185, 129, 0.15);
  color: #10B981;
}
.badge.brand {
  background: var(--color-brand-faint);
  color: var(--color-brand);
}
.sidebar-logo {
  padding: 20px 16px;
  border-bottom: 1px solid var(--color-divider);
  display: flex;
  align-items: center;
  gap: 10px;
}
.sidebar-logo .logo-icon {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: var(--gradient-brand);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  font-weight: 900;
  color: white;
}
.sidebar-logo .logo-text {
  font-size: 17px;
  font-weight: 800;
  color: #FFFFFF;
  letter-spacing: -0.02em;
}
.sidebar-logo .logo-sub {
  font-size: 9px;
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.12em;
}
.nav-section {
  padding: 12px 16px 4px;
  font-size: 10px;
  font-weight: 700;
  color: var(--color-text-disabled);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}
.nav-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 16px;
  color: var(--color-text-secondary);
  cursor: pointer;
  border-radius: 8px;
  margin: 2px 8px;
  transition: all 0.15s ease;
  font-size: 14px;
  font-weight: 500;
  text-decoration: none;
  -webkit-user-select: none;
  user-select: none;
}
.nav-item:hover {
  background: rgba(255, 255, 255, 0.05);
  color: var(--color-text-primary);
}
.nav-item.active {
  background: var(--color-brand-faint);
  color: var(--color-brand-light);
  border-left: 3px solid var(--color-brand);
  padding-left: 11px;
}
.nav-item.disabled {
  opacity: 0.35;
  cursor: not-allowed;
  pointer-events: none;
}
.nav-item .nav-icon {
  font-size: 15px;
  width: 18px;
  flex-shrink: 0;
}
.nav-item .nav-label {
  flex: 1;
  white-space: nowrap;
  overflow: hidden;
}
.nav-item .nav-badge {
  background: var(--color-error);
  color: white;
  font-size: 10px;
  font-weight: 700;
  padding: 1px 6px;
  border-radius: 10px;
  min-width: 18px;
  text-align: center;
}
.nav-item .nav-arrow {
  font-size: 10px;
  transition: transform 0.2s;
}
.nav-item .nav-arrow.open {
  transform: rotate(90deg);
}
.nav-children {
  overflow: hidden;
  transition: max-height 0.25s ease;
  max-height: 0;
}
.nav-children.open {
  max-height: 600px;
}
.nav-children .nav-item {
  padding-left: 40px;
  font-size: 12.5px;
  margin: 1px 8px;
}
.nav-children .nav-item.active {
  padding-left: 37px;
}
.topbar-title {
  font-size: 15px;
  font-weight: 600;
  color: var(--color-text-primary);
  flex: 1;
}
.topbar-actions {
  display: flex;
  align-items: center;
  gap: 12px;
}
.topbar-user {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  border-radius: 8px;
  cursor: pointer;
  transition: background 0.15s;
  border: 1px solid transparent;
}
.topbar-user:hover {
  background: rgba(255, 255, 255, 0.06);
  border-color: var(--color-divider);
}
.topbar-user .user-name {
  font-size: 13px;
  font-weight: 600;
  color: var(--color-text-primary);
}
.topbar-user .user-role {
  font-size: 11px;
  color: var(--color-text-muted);
}
.topbar-user .user-avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--gradient-brand);
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  font-size: 13px;
  font-weight: 700;
}
.date-range-picker {
  display: flex;
  align-items: center;
  gap: 6px;
  background: var(--color-surface);
  border: 1px solid var(--color-divider);
  border-radius: 8px;
  padding: 6px 10px;
}
.date-range-picker .preset-btn {
  padding: 4px 10px;
  border-radius: 6px;
  font-size: 12px;
  font-weight: 500;
  border: none;
  background: transparent;
  color: var(--color-text-secondary);
  cursor: pointer;
  transition: all 0.15s;
}
.date-range-picker .preset-btn:hover {
  background: rgba(255, 255, 255, 0.06);
  color: var(--color-text-primary);
}
.date-range-picker .preset-btn.active {
  background: var(--color-brand-faint);
  color: var(--color-brand);
}
.date-range-picker .date-input {
  padding: 4px 8px;
  border: 1px solid var(--color-divider);
  border-radius: 6px;
  background: var(--color-surface-elevated);
  color: var(--color-text-primary);
  font-size: 12px;
  outline: none;
}
.date-range-picker .date-input:focus {
  border-color: var(--color-brand);
}
.data-table-wrapper {
  background: var(--bg-card);
  border-radius: 12px;
  border: 1px solid var(--color-divider);
  overflow: hidden;
}
.table-filters {
  padding: 16px;
  border-bottom: 1px solid var(--color-divider);
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
}
.filter-input,
.filter-select {
  padding: 7px 12px;
  border: 1px solid var(--color-divider);
  border-radius: 8px;
  font-size: 13px;
  outline: none;
  background: var(--color-surface-elevated);
  color: var(--color-text-primary);
}
.filter-input:focus,
.filter-select:focus {
  border-color: var(--color-brand);
}
.filter-input::placeholder,
.filter-select::placeholder {
  color: var(--color-text-muted);
}
.filter-input {
  min-width: 160px;
}
.filter-select {
  cursor: pointer;
}
table.dopplos-table {
  width: 100%;
  border-collapse: collapse;
}
table.dopplos-table th {
  padding: 13px 18px;
  text-align: left;
  font-size: 13px;
  font-weight: 600;
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  background: rgba(255, 255, 255, 0.02);
  border-bottom: 1px solid var(--color-divider);
  white-space: nowrap;
}
table.dopplos-table th.sortable {
  cursor: pointer;
}
table.dopplos-table th.sortable:hover {
  color: var(--color-brand);
}
table.dopplos-table td {
  padding: 15px 18px;
  font-size: 15px;
  color: var(--color-text-secondary);
  border-bottom: 1px solid rgba(42, 42, 42, 0.6);
  vertical-align: middle;
}
table.dopplos-table tr:hover td {
  background: rgba(255, 255, 255, 0.02);
}
table.dopplos-table tr:last-child td {
  border-bottom: none;
}
.table-pagination {
  padding: 14px 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-top: 1px solid var(--color-divider);
  font-size: 13px;
  color: var(--color-text-muted);
}
.table-pagination .pagination-buttons {
  display: flex;
  gap: 4px;
}
.table-pagination .page-btn {
  width: 32px;
  height: 32px;
  border-radius: 6px;
  border: 1px solid var(--color-divider);
  background: transparent;
  color: var(--color-text-secondary);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
}
.table-pagination .page-btn:hover {
  background: rgba(255, 255, 255, 0.05);
}
.table-pagination .page-btn.active {
  background: var(--color-brand);
  color: white;
  border-color: var(--color-brand);
}
.table-pagination .page-btn:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}
.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 20px;
  border-radius: 9px;
  font-size: 15px;
  font-weight: 600;
  border: none;
  cursor: pointer;
  transition: all 0.15s;
  font-family: var(--font-family);
}
.btn.btn-primary {
  background: var(--gradient-brand);
  color: white;
}
.btn.btn-primary:hover {
  opacity: 0.9;
  transform: translateY(-1px);
}
.btn.btn-danger {
  background: rgba(239, 68, 68, 0.15);
  color: #EF4444;
  border: 1px solid rgba(239, 68, 68, 0.3);
}
.btn.btn-danger:hover {
  background: rgba(239, 68, 68, 0.25);
}
.btn.btn-secondary {
  background: rgba(255, 255, 255, 0.06);
  color: var(--color-text-primary);
  border: 1px solid var(--color-divider);
}
.btn.btn-secondary:hover {
  background: rgba(255, 255, 255, 0.1);
}
.btn.btn-ghost {
  background: transparent;
  color: var(--color-text-secondary);
}
.btn.btn-ghost:hover {
  background: rgba(255, 255, 255, 0.05);
}
.btn.btn-sm {
  padding: 5px 12px;
  font-size: 12px;
}
.btn:disabled {
  opacity: 0.4;
  cursor: not-allowed;
  pointer-events: none;
}
.drawer-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  z-index: 200;
  opacity: 0;
  transition: opacity 0.25s;
  pointer-events: none;
}
.drawer-overlay.visible {
  opacity: 1;
  pointer-events: all;
}
.drawer {
  position: fixed;
  top: 0;
  right: 0;
  height: 100vh;
  width: 620px;
  background: var(--color-surface);
  z-index: 201;
  transform: translateX(100%);
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  display: flex;
  flex-direction: column;
  box-shadow: -8px 0 32px rgba(0, 0, 0, 0.4);
  border-left: 1px solid var(--color-divider);
}
.drawer.visible {
  transform: translateX(0);
}
.drawer .drawer-header {
  padding: 24px 28px;
  border-bottom: 1px solid var(--color-divider);
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-shrink: 0;
}
.drawer .drawer-header h3 {
  font-size: 19px;
  font-weight: 700;
  color: var(--color-text-primary);
}
.drawer .drawer-body {
  flex: 1;
  overflow-y: auto;
  padding: 28px;
}
.drawer .drawer-footer {
  padding: 20px 28px;
  border-top: 1px solid var(--color-divider);
  display: flex;
  gap: 12px;
  justify-content: flex-end;
  flex-shrink: 0;
}
.dialog-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.65);
  z-index: 300;
  display: flex;
  align-items: center;
  justify-content: center;
}
.dialog {
  background: var(--color-surface-elevated);
  border-radius: 18px;
  width: 100%;
  max-width: 640px;
  max-height: 92vh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: 0 25px 60px rgba(0, 0, 0, 0.5);
  border: 1px solid var(--color-divider);
}
.dialog .dialog-header {
  padding: 24px 28px;
  border-bottom: 1px solid var(--color-divider);
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.dialog .dialog-header h3 {
  font-size: 19px;
  font-weight: 700;
  color: var(--color-text-primary);
}
.dialog .dialog-body {
  padding: 28px;
  overflow-y: auto;
  flex: 1;
}
.dialog .dialog-footer {
  padding: 20px 28px;
  border-top: 1px solid var(--color-divider);
  display: flex;
  gap: 12px;
  justify-content: flex-end;
}
.form-group {
  margin-bottom: 20px;
}
.form-group label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: var(--color-text-secondary);
  margin-bottom: 7px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.form-group input,
.form-group select,
.form-group textarea {
  width: 100%;
  padding: 11px 14px;
  border: 1px solid var(--color-divider);
  border-radius: 9px;
  font-size: 15px;
  outline: none;
  font-family: var(--font-family);
  background: var(--color-bg);
  color: var(--color-text-primary);
  transition: border-color 0.15s;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color: var(--color-brand);
  box-shadow: 0 0 0 3px var(--color-brand-faint);
}
.form-group input:disabled,
.form-group select:disabled,
.form-group textarea:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.form-group input::placeholder,
.form-group select::placeholder,
.form-group textarea::placeholder {
  color: var(--color-text-muted);
}
.form-group textarea {
  resize: vertical;
  min-height: 100px;
}
.form-group select option {
  background: var(--color-surface);
}
.form-group .form-hint {
  font-size: 13px;
  color: var(--color-text-muted);
  margin-top: 5px;
}
.form-group .form-error {
  font-size: 13px;
  color: var(--color-error);
  margin-top: 5px;
}
@keyframes shimmer {
  0% {
    background-position: -200% 0;
  }
  100% {
    background-position: 200% 0;
  }
}
.skeleton {
  background:
    linear-gradient(
      90deg,
      #1F1F1F 25%,
      #2A2A2A 50%,
      #1F1F1F 75%);
  background-size: 200% 100%;
  animation: shimmer 1.5s infinite;
  border-radius: 6px;
}
.skeleton.skeleton-text {
  height: 14px;
  margin-bottom: 8px;
}
.skeleton.skeleton-title {
  height: 22px;
  width: 60%;
  margin-bottom: 12px;
}
.skeleton.skeleton-card {
  height: 120px;
  border-radius: 12px;
}
.skeleton.skeleton-chart {
  height: 280px;
  border-radius: 12px;
}
.login-page {
  min-height: 100vh;
  background: var(--gradient-bg);
  display: flex;
  align-items: center;
  justify-content: center;
}
.login-card {
  background: var(--color-surface);
  border-radius: 20px;
  padding: 40px;
  width: 100%;
  max-width: 420px;
  box-shadow: 0 25px 60px rgba(0, 0, 0, 0.5);
  border: 1px solid var(--color-divider);
}
.login-card .login-logo {
  text-align: center;
  margin-bottom: 32px;
}
.login-card .login-logo .login-brand-icon {
  width: 60px;
  height: 60px;
  border-radius: 16px;
  background: var(--gradient-brand);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 16px;
  font-size: 28px;
  font-weight: 900;
  color: white;
}
.login-card .login-logo h1 {
  font-size: 26px;
  font-weight: 800;
  color: var(--color-text-primary);
  letter-spacing: -0.03em;
}
.login-card .login-logo p {
  font-size: 13px;
  color: var(--color-text-muted);
  margin-top: 6px;
}
.tabs {
  display: flex;
  border-bottom: 1px solid var(--color-divider);
  margin-bottom: 20px;
}
.tabs .tab {
  padding: 10px 20px;
  font-size: 13px;
  font-weight: 500;
  color: var(--color-text-secondary);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  transition: all 0.15s;
}
.tabs .tab:hover {
  color: var(--color-text-primary);
}
.tabs .tab.active {
  color: var(--color-brand);
  border-bottom-color: var(--color-brand);
  font-weight: 600;
}
.alert {
  padding: 12px 16px;
  border-radius: 8px;
  font-size: 13px;
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 16px;
}
.alert.alert-success {
  background: rgba(34, 197, 94, 0.12);
  color: #22C55E;
  border: 1px solid rgba(34, 197, 94, 0.25);
}
.alert.alert-error {
  background: rgba(239, 68, 68, 0.12);
  color: #EF4444;
  border: 1px solid rgba(239, 68, 68, 0.25);
}
.alert.alert-warning {
  background: rgba(245, 158, 11, 0.12);
  color: #F59E0B;
  border: 1px solid rgba(245, 158, 11, 0.25);
}
.alert.alert-info {
  background: rgba(59, 130, 246, 0.12);
  color: #3B82F6;
  border: 1px solid rgba(59, 130, 246, 0.25);
}
.progress-bar-wrapper {
  height: 6px;
  background: rgba(255, 255, 255, 0.06);
  border-radius: 3px;
  overflow: hidden;
}
.progress-bar-wrapper .progress-bar-fill {
  height: 100%;
  border-radius: 3px;
  transition: width 0.5s ease;
}
.progress-bar-wrapper .progress-bar-fill.green {
  background: #22C55E;
}
.progress-bar-wrapper .progress-bar-fill.yellow {
  background: #F59E0B;
}
.progress-bar-wrapper .progress-bar-fill.red {
  background: #EF4444;
}
.progress-bar-wrapper .progress-bar-fill.blue {
  background: #3B82F6;
}
.progress-bar-wrapper .progress-bar-fill.brand {
  background: var(--gradient-brand);
}
.text-brand {
  color: var(--color-brand);
}
.text-green {
  color: #22C55E;
}
.text-red {
  color: #EF4444;
}
.text-yellow {
  color: #F59E0B;
}
.text-blue {
  color: #3B82F6;
}
.text-muted {
  color: var(--color-text-muted);
}
.text-small {
  font-size: 12px;
}
.text-bold {
  font-weight: 700;
}
.text-primary {
  color: var(--color-text-primary);
}
.text-secondary {
  color: var(--color-text-secondary);
}
.flex {
  display: flex;
}
.flex-col {
  flex-direction: column;
}
.items-center {
  align-items: center;
}
.justify-between {
  justify-content: space-between;
}
.gap-2 {
  gap: 8px;
}
.gap-3 {
  gap: 12px;
}
.gap-4 {
  gap: 16px;
}
.mb-4 {
  margin-bottom: 16px;
}
.mb-6 {
  margin-bottom: 24px;
}
.mt-4 {
  margin-top: 16px;
}
.w-full {
  width: 100%;
}
.divider {
  height: 1px;
  background: var(--color-divider);
  margin: 16px 0;
}
::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}
::-webkit-scrollbar-track {
  background: transparent;
}
::-webkit-scrollbar-thumb {
  background: #2A2A2A;
  border-radius: 3px;
}
::-webkit-scrollbar-thumb:hover {
  background: #3A3A3A;
}
@media (max-width: 1280px) {
  .kpi-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .card-grid.cols-4 {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 768px) {
  .app-sidebar {
    display: none;
  }
  .kpi-grid {
    grid-template-columns: 1fr;
  }
  .card-grid {
    grid-template-columns: 1fr !important;
  }
  .app-content {
    padding: 16px;
  }
  .drawer {
    width: 100%;
  }
}

/* angular:styles/global:styles */
/*# sourceMappingURL=styles.css.map */
