@charset "UTF-8";

:root {
  /* ========================================
     Azure Guardian Design System Colors
     ======================================== */
  /* Base Colors - 基礎色彩 */
  --white: #FFFFFF;
  --color-w: #ffffff; /* 保留向下相容 */
  --black: #000000;
  --mine-shaft: #333333;
  --gray-dark: #393939; /* 保留現有，與 mine-shaft 相近 */
  /* Primary Brand Colors - 主要品牌色 */
  --deep-cerulean: #0078A8; /* Azure Guardian 主色 */
  --royal-blue: #0078A8;
  --primary: #4289C3; /* 保留現有主色 */
  --main-color: #4289C3; /* 保留向下相容 */
  /* Secondary Colors - 次要色彩 */
  --secondary: #F57F34;
  --orange: #FC9D18;
  --gold: #FFD500;
  --corn: #E0BC00;
  /* Gray Scale - 灰階系統 */
  --athens-gray: #F3F4F6;
  --athens-gray-dark: #E5E7EB;
  --gray-chateau: #9CA3AF;
  --silver: #CCCCCC;
  --text: #707070; /* 保留現有 */
  --l-g: #ebebeb; /* 保留現有 */
  /* Surface Hierarchy - 表面層級系統（Glassmorphism）*/
  --surface: #f7fafc;
  --surface-container-lowest: #ffffff;
  --surface-container-low: #f1f5f9;
  --surface-container: #e2e8f0;
  --surface-container-high: #cbd5e1;
  --surface-container-highest: #94a3b8;
  --surface-variant: rgba(226, 232, 240, 0.6); /* 60% opacity for glass effect */
  /* On-Surface Text Colors - 表面文字色彩 */
  --on-surface: #181c1e;
  --on-primary-fixed: #000000;
  /* Outline & Borders - 輪廓與邊框 */
  --outline-variant: rgba(203, 213, 225, 0.15); /* Ghost Border */
  --border-color: #e2e8f0; /* 保留向下相容 */
  /* Background Colors - 背景色系 */
  --bg-lb: #ECF5F7; /* 保留現有 */
  --bg-lo: #ffe3d1; /* 保留現有 */
  --bg-hover: rgba(66, 137, 195, 0.08);
  /* Status Colors - 狀態色彩 */
  --success: #28a745;
  --success-light: rgba(40, 167, 69, 0.1);
  --info: #17a2b8;
  --warning: #F35D82;
  --warning-light: rgba(243, 93, 130, 0.1);
  --danger: #dc3545;
  --danger-light: rgba(220, 53, 69, 0.1);
  /* Legacy Theme Colors - 保留舊有主題色 */
  --light: #D8D8E4;
  --dark: #343a40;
  --green: #68B83A;
  --purple: #5A6BBA;
  --l-purple: #E6D9F2;
  --l-y: #FFF3D1;
  --l-pi: #FEE8EF;
  --l-gr: #D9EBCF;
  --l-b: #E2F8FD;
  --teal-b: #20B5AA;
  /* Gradient - 漸層系統 */
  --gradient-azure: linear-gradient(135deg, #0078A8 0%, #4289C3 100%);
  --gradient-deep-lake: linear-gradient(180deg, #0078A8 0%, #4289C3 50%, #E2F8FD 100%);
  /* ========================================
     Elevation & Shadows - 高度與陰影
     ======================================== */
  /* Ambient Shadows - 環境陰影 */
  --shadow-ambient-sm: 0 2px 8px rgba(24, 28, 30, 0.06);
  --shadow-ambient-md: 0 4px 16px rgba(24, 28, 30, 0.06);
  --shadow-ambient-lg: 0 8px 32px rgba(24, 28, 30, 0.06);
  /* Legacy Shadow - 保留舊有陰影 */
  --shadow1: 6px 5px 4px rgba(0, 0, 0, 0.14);
  --shadow-card: 0 2px 4px rgba(0, 0, 0, 0.1);
  --shadow-hover: 0 4px 8px rgba(0, 0, 0, 0.15);
  /* Glassmorphism Effect - 玻璃形態效果 */
  --glass-blur: 20px;
  --glass-opacity: 0.6;
  /* ========================================
     Spacing & Sizing System - 間距與尺寸系統
     ======================================== */
  /* Layout Spacing - 佈局間距 */
  --spacing-1: 0.25rem; /* 4px */
  --spacing-2: 0.5rem; /* 8px */
  --spacing-3: 0.75rem; /* 12px */
  --spacing-4: 1rem; /* 16px */
  --spacing-5: 1.25rem; /* 20px */
  --spacing-6: 1.5rem; /* 24px - Breathing space */
  --spacing-7: 1.75rem; /* 28px */
  --spacing-8: 2rem; /* 32px - Breathing space */
  --spacing-10: 2.5rem; /* 40px */
  --spacing-12: 3rem; /* 48px */
  --spacing-16: 4rem; /* 64px */
  /* Legacy Size Variables - 保留現有尺寸變數 */
  --full_width: 100vw;
  --size_8: 0.5rem; /* 8px - 新增補充 */
  --size_10: 0.625rem; /* 10px - 新增補充 */
  --size_12: 0.75rem;
  --size_13: 0.8125rem;
  --size_14: 0.875rem;
  --size_15: 0.9375rem;
  --size_16: 1rem;
  --size_17: 1.0625rem;
  --size_18: 1.125rem;
  --size_19: 1.1875rem;
  --size_20: 1.25rem;
  --size_21: 1.3125rem;
  --size_22: 1.375rem;
  --size_23: 1.4375em;
  --size_24: 1.5rem;
  --size_25: 1.5625rem;
  --size_26: 1.625rem;
  --size_27: 1.6875rem;
  --size_28: 1.75rem;
  --size_30: 1.875rem;
  --size_33: 2.0625rem;
  --size_38: 2.375rem;
  --size_40: 2.5rem;
  --size_42: 2.625rem;
  --size_48: 3rem;
  /* ========================================
     Typography Scale - 字體尺寸系統
     ======================================== */
  /* Display Sizes - 展示用大標題 */
  --display-lg: 3.5rem; /* 56px - Magazine-style entry point */
  --display-md: 2.75rem; /* 44px */
  --display-sm: 2.25rem; /* 36px */
  /* Heading Sizes - 標題尺寸 */
  --heading-xl: 2rem; /* 32px */
  --heading-lg: 1.75rem; /* 28px */
  --heading-md: 1.5rem; /* 24px */
  --heading-sm: 1.25rem; /* 20px */
  --heading-xs: 1.125rem; /* 18px */
  /* Body Text Sizes - 內文尺寸 */
  --body-lg: 1.125rem; /* 18px */
  --body-md: 1rem; /* 16px */
  --body-sm: 0.875rem; /* 14px */
  --body-xs: 0.75rem; /* 12px */
  /* ========================================
     Border Radius - 圓角系統
     ======================================== */
  /* Rounded Corners */
  --radius-sm: 0.25rem; /* 4px */
  --radius-md: 0.75rem; /* 12px - Main panels */
  --radius-lg: 1rem; /* 16px */
  --radius-xl: 1.5rem; /* 24px - Floating elements */
  --radius-full: 9999px; /* Full rounded */
  /* ========================================
     Transitions & Animations - 過渡與動畫
     ======================================== */
  --transition-fast: 150ms ease-in-out;
  --transition-base: 250ms ease-in-out;
  --transition-slow: 350ms ease-in-out;
  --transition-glass: 300ms cubic-bezier(0.4, 0, 0.2, 1);
}

/* ========================================
   Azure Guardian Design System
   高階環境衛生管理系統設計規範
   ======================================== */
/* ==========================================================================
   Surface & Glassmorphism - 表面層級與玻璃形態效果
   ========================================================================== */
.surface {
  background: var(--surface);
}

.surface-container-lowest {
  background: var(--surface-container-lowest);
  -webkit-box-shadow: var(--shadow-ambient-sm);
          box-shadow: var(--shadow-ambient-sm);
}

.surface-container-low {
  background: var(--surface-container-low);
}

.surface-container {
  background: var(--surface-container);
}

.surface-container-high {
  background: var(--surface-container-high);
}

.surface-container-highest {
  background: var(--surface-container-highest);
}

.glass-card {
  background: var(--surface-variant);
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
  border-radius: var(--radius-md);
  border: 1px solid var(--outline-variant);
  -webkit-transition: var(--transition-glass);
  transition: var(--transition-glass);
}
.glass-card:hover {
  -webkit-box-shadow: var(--shadow-ambient-md);
          box-shadow: var(--shadow-ambient-md);
  -webkit-transform: translateY(-2px);
          transform: translateY(-2px);
}

.glass-panel {
  background: rgba(255, 255, 255, var(--glass-opacity));
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
  border: 1px solid var(--outline-variant);
}

/* ==========================================================================
   Gradient Backgrounds - 漸層背景（Deep-to-Lake Gradient）
   ========================================================================== */
.gradient-azure {
  background: var(--gradient-azure);
  color: var(--white);
}

.gradient-deep-lake {
  background: var(--gradient-deep-lake);
  color: var(--on-surface);
}

/* ==========================================================================
   Premium Cards - 高階卡片（No-Border Principle）
   ========================================================================== */
.premium-card {
  background: var(--surface-container-lowest);
  border-radius: var(--radius-md);
  padding: var(--spacing-6);
  -webkit-box-shadow: var(--shadow-ambient-sm);
          box-shadow: var(--shadow-ambient-sm);
  border: none; /* 嚴格禁止使用 1px solid border */
  -webkit-transition: var(--transition-base);
  transition: var(--transition-base);
}
.premium-card:hover {
  -webkit-box-shadow: var(--shadow-ambient-md);
          box-shadow: var(--shadow-ambient-md);
  -webkit-transform: translateY(-2px);
          transform: translateY(-2px);
}
.premium-card .premium-card-nested {
  background: var(--surface-container-low);
  padding: var(--spacing-4);
  border-radius: var(--radius-sm);
}

.data-card {
  background: var(--surface-container-lowest);
  border-radius: var(--radius-md);
  padding: var(--spacing-8); /* 使用 spacing.8 創造呼吸空間 */
  -webkit-box-shadow: var(--shadow-ambient-sm);
          box-shadow: var(--shadow-ambient-sm);
  margin-bottom: var(--spacing-6);
}
.data-card .card-header {
  font-size: var(--heading-md);
  font-weight: 600;
  color: var(--on-surface);
  margin-bottom: var(--spacing-6);
}
.data-card .card-divider {
  height: 1px;
  background: var(--surface-container);
  margin: var(--spacing-6) 0;
  border: none; /* 使用背景色而非 border */
}

/* ==========================================================================
   Buttons & CTA - 按鈕與行動呼籲（Gradient + Lift Effect）
   ========================================================================== */
.btn-azure-primary {
  background: var(--gradient-azure);
  border: none;
  border-radius: var(--radius-xl);
  padding: var(--spacing-3) var(--spacing-6);
  color: var(--white);
  font-weight: 500;
  font-size: var(--body-md);
  cursor: pointer;
  -webkit-transition: var(--transition-base);
  transition: var(--transition-base);
  -webkit-box-shadow: var(--shadow-ambient-sm);
          box-shadow: var(--shadow-ambient-sm);
}
.btn-azure-primary:hover {
  -webkit-box-shadow: var(--shadow-ambient-lg);
          box-shadow: var(--shadow-ambient-lg);
  -webkit-transform: translateY(-2px);
          transform: translateY(-2px);
}
.btn-azure-primary:active {
  -webkit-transform: translateY(0);
          transform: translateY(0);
}

.btn-azure-secondary {
  background: transparent;
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-xl);
  padding: var(--spacing-3) var(--spacing-6);
  color: var(--deep-cerulean);
  font-weight: 500;
  font-size: var(--body-md);
  cursor: pointer;
  -webkit-transition: var(--transition-base);
  transition: var(--transition-base);
}
.btn-azure-secondary:hover {
  background: var(--surface-container-low);
  border-color: var(--deep-cerulean);
}

.btn-glass {
  background: var(--surface-variant);
  backdrop-filter: blur(var(--glass-blur));
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-full);
  padding: var(--spacing-3) var(--spacing-5);
  color: var(--on-surface);
  font-size: var(--body-sm);
  cursor: pointer;
  -webkit-transition: var(--transition-glass);
  transition: var(--transition-glass);
}
.btn-glass:hover {
  background: rgba(255, 255, 255, 0.9);
  -webkit-box-shadow: var(--shadow-ambient-md);
          box-shadow: var(--shadow-ambient-md);
}

/* ==========================================================================
   Typography - 雙字體系統（Manrope + Inter）
   ========================================================================== */
.display-heading {
  font-size: var(--display-lg);
  font-weight: 700;
  line-height: 1.1;
  color: var(--on-surface);
  margin-bottom: var(--spacing-6);
}
.display-heading.display-md {
  font-size: var(--display-md);
}
.display-heading.display-sm {
  font-size: var(--display-sm);
}

.heading-authority {
  font-size: var(--heading-lg);
  font-weight: 600;
  color: var(--on-primary-fixed);
  line-height: 1.3;
  margin-bottom: var(--spacing-4);
}

.body-text {
  font-size: var(--body-md);
  line-height: 1.6;
  color: var(--on-surface);
}
.body-text.body-lg {
  font-size: var(--body-lg);
}
.body-text.body-sm {
  font-size: var(--body-sm);
}

/* ==========================================================================
   Spacing Utilities - 呼吸空間工具類別
   ========================================================================== */
.breathing-space {
  padding: var(--spacing-8);
}

.breathing-vertical {
  padding-top: var(--spacing-8);
  padding-bottom: var(--spacing-8);
}

.breathing-horizontal {
  padding-left: var(--spacing-6);
  padding-right: var(--spacing-6);
}

/* ==========================================================================
   Ambient Shadows - 環境陰影
   ========================================================================== */
.shadow-ambient-sm {
  -webkit-box-shadow: var(--shadow-ambient-sm);
          box-shadow: var(--shadow-ambient-sm);
}

.shadow-ambient-md {
  -webkit-box-shadow: var(--shadow-ambient-md);
          box-shadow: var(--shadow-ambient-md);
}

.shadow-ambient-lg {
  -webkit-box-shadow: var(--shadow-ambient-lg);
          box-shadow: var(--shadow-ambient-lg);
}

.float-lift {
  position: relative;
  z-index: 10;
  -webkit-box-shadow: var(--shadow-ambient-md);
          box-shadow: var(--shadow-ambient-md);
  -webkit-transition: var(--transition-base);
  transition: var(--transition-base);
}
.float-lift:hover {
  -webkit-box-shadow: var(--shadow-ambient-lg);
          box-shadow: var(--shadow-ambient-lg);
  -webkit-transform: translateY(-4px);
          transform: translateY(-4px);
}

/* ==========================================================================
   Search & Filters - 搜尋與篩選（Glassmorphism）
   ========================================================================== */
.search-bar-glass {
  background: var(--surface-container-high);
  border-radius: var(--radius-full);
  padding: var(--spacing-3) var(--spacing-5);
  border: 1px solid var(--outline-variant);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: var(--spacing-3);
  -webkit-box-shadow: var(--shadow-ambient-sm);
          box-shadow: var(--shadow-ambient-sm);
}
.search-bar-glass input {
  border: none;
  background: transparent;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  font-size: var(--body-md);
  color: var(--on-surface);
}
.search-bar-glass input::-webkit-input-placeholder {
  color: var(--gray-chateau);
}
.search-bar-glass input::-moz-placeholder {
  color: var(--gray-chateau);
}
.search-bar-glass input:-ms-input-placeholder {
  color: var(--gray-chateau);
}
.search-bar-glass input::-ms-input-placeholder {
  color: var(--gray-chateau);
}
.search-bar-glass input::placeholder {
  color: var(--gray-chateau);
}
.search-bar-glass input:focus {
  outline: none;
}

.filter-glass-panel {
  background: var(--surface-variant);
  backdrop-filter: blur(var(--glass-blur));
  border-radius: var(--radius-lg);
  padding: var(--spacing-6);
  margin-top: var(--spacing-5);
  border: 1px solid var(--outline-variant);
  -webkit-box-shadow: var(--shadow-ambient-md);
          box-shadow: var(--shadow-ambient-md);
}

/* ==========================================================================
   Asymmetric Layout - 非對稱排版（Editorial Style）
   ========================================================================== */
.asymmetric-grid {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr var(--spacing-8) 2fr;
  grid-template-columns: 1fr 2fr;
  gap: var(--spacing-8);
}
@media (max-width: 768px) {
  .asymmetric-grid {
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
  }
}

.left-hero-text h1 {
  font-size: var(--display-lg);
  font-weight: 700;
  text-align: left;
  line-height: 1.1;
  color: var(--on-surface);
}

/* ======================================== End of Azure Guardian System */
.page-content-area {
  position: relative;
}

.create {
  position: absolute;
  right: 24px;
  top: 8px;
}

.dropdown-create .btn-create::after {
  display: none;
}
.dropdown-create .dropdown-item:hover {
  color: var(--primary);
  background: var(--bg-lb);
}
.dropdown-create .fad {
  color: var(--primary);
}

.sectionNav-wrap, .form-body {
  background: var(--color-w);
  border-radius: 10px;
  padding: 2rem;
}

.row-offcanvas {
  margin: 1rem 0;
}

/*<!--左側選單 -->*/
.col.sidebar-offcanvas {
  -ms-flex: 0 0 230px;
  -webkit-box-flex: 0;
          flex: 0 0 230px;
}

.section-nav ul {
  padding-left: 0rem;
  width: 100%;
  position: relative;
}
.section-nav ul::before {
  content: "";
  display: block;
  position: absolute;
  width: 5px;
  height: 100%;
  background: var(--light);
  top: 0;
  left: 0;
}
.section-nav li {
  list-style: none;
  margin-bottom: 0;
  width: 100%;
}
.section-nav li a {
  display: block;
  width: 100%;
  padding: 0.5rem 1.5rem 0.5rem 1rem;
  border-left: var(--light) solid 5px;
  color: var(--text);
  position: relative;
  font-size: var(--size_16);
  line-height: 22px;
  -webkit-transition: -webkit-transform 0.3s ease-in-out;
  transition: -webkit-transform 0.3s ease-in-out;
  transition: transform 0.3s ease-in-out;
  transition: transform 0.3s ease-in-out, -webkit-transform 0.3s ease-in-out;
}
.section-nav li a.active {
  color: var(--secondary);
  border-color: var(--secondary);
}

/* .affix-top .section-nav, */
.col.sidebar-offcanvas.affix-top {
  -ms-flex: 0 0 230px;
  -webkit-box-flex: 0;
          flex: 0 0 230px;
}

.affix-top .sectionNav-wrap {
  position: fixed;
  top: 65px;
  margin-top: 0;
  -webkit-transition: opacity 0.5s ease-out;
  transition: opacity 0.5s ease-out;
  z-index: 200;
  width: 220px;
}

/* .main-content .affix-top .section-nav, */
.affix-top + div #btnSub {
  position: fixed;
  z-index: 1;
  top: 0;
  left: 0;
  border-radius: 0;
}

/*右側content*/
.form-body section {
  padding-top: 2rem;
  position: relative;
  display: block;
}
.form-body section .collapse {
  padding: 1rem;
}
.form-body section .form-check {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.form-body section:last-child {
  min-height: 10vh;
}
.form-body section.active {
  margin-top: 10px;
}
.form-body section.active .collapse {
  -webkit-transition: all 0s ease-in-out;
  transition: all 0s ease-in-out;
  background: #f7f7f7;
  padding: 20px;
  margin: 20px 0;
  border: 1px dashed #e2e2e2;
}
.form-body .section-title {
  color: var(--text);
  font-size: 1.25rem;
  line-height: 1.6rem;
  margin-bottom: 0.5rem;
  border-bottom: 1px solid var(--text);
  background: transparent;
}
.form-body .section-title .btn {
  border-radius: 0;
  display: block;
  width: 100%;
  text-align: left;
}
.form-body .section-title .btn .fas {
  font-weight: bold;
  font-size: var(--size_17);
  margin-right: 0.15rem;
  color: var(--secondary);
}
.form-body .tab-content section:last-child {
  padding-bottom: 0;
  min-height: auto;
}
.form-body .section-body .nav-pills .nav-item .nav-link {
  font-size: var(--size_18);
}
.form-body .section-body section {
  padding-bottom: 1rem;
}
.form-body .section-body .check-likeqnr input[type=checkbox] + label {
  border: 0px;
  background: transparent;
  padding: 2px 0 2px 25px;
  margin: 0 0 0.3rem 0.5rem;
}
.form-body .section-body .nav-pills .nav-item [id*=score] {
  border: 1px solid #cccccc;
}
.form-body .section-body .nav-pills .nav-item:first-child [id*=score] {
  border-radius: 30px 0 0 30px;
}
.form-body .section-body .nav-pills .nav-item:first-child [id*=score].active {
  color: var(--secondary);
  background-color: #fae8dd;
  border: 1px solid var(--secondary);
}
.form-body .section-body .nav-pills .nav-item:first-child [id*=score].active .fa-minus {
  color: var(--secondary);
}
.form-body .section-body .nav-pills .nav-item:last-child [id*=score] {
  border-radius: 0px 30px 30px 0;
}
.form-body .section-body .nav-pills .nav-item:last-child [id*=score].active {
  color: var(--primary);
  border: 1px solid var(--primary);
  background-color: #d6e8f6;
}
.form-body .section-body .nav-pills .nav-item:last-child [id*=score].active .fa-plus {
  color: var(--primary);
}

.openhour-wrapper .btn-open {
  float: right;
  padding: 8px 15px;
}
.openhour-wrapper .nav-pills {
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}
.openhour-wrapper .nav-pills .nav-link,
.openhour-wrapper .nav-pills .nav-link.active, .openhour-wrapper .nav-pills .nav-link.active:focus, .openhour-wrapper .nav-pills .nav-link:focus {
  color: var(--text);
  width: 50px;
  height: 50px;
  border-radius: 50px;
  margin-right: 3px;
  font-size: var(--size_18);
}
.openhour-wrapper .nav-pills .nav-link.active, .openhour-wrapper .nav-pills .nav-link.active:focus {
  color: var(--color-w);
  background: var(--primary);
}
.openhour-wrapper .btn-more {
  float: right;
  margin-top: -0.2rem;
  padding: 0px;
}
.openhour-wrapper .newhour {
  display: none;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
  position: relative;
}
.openhour-wrapper .newhour .btn-delete {
  background: rgba(255, 255, 255, 0);
  border: 0px;
  font-size: var(--size_20);
  position: absolute;
  opacity: 0.5;
  right: -35px;
  top: 30px;
}

.form-btn-group {
  padding: 1rem 1rem;
  text-align: center;
}
.form-btn-group .btn {
  color: var(--color-w);
}
.form-btn-group .btn-secondary {
  font-size: var(--size_18);
  font-weight: normal;
}

/*扣10分*/
h5.deduct-subtitle {
  background: #ededed;
  padding: 7px 15px 5px;
  font-size: var(--size_16);
  font-weight: bold;
  margin-bottom: 5px;
}

[class*=col-md].left, [class*=col-md].center {
  border-right: 1px solid #e6e6e6;
}

.score {
  background: var(--secondary);
  color: var(--color-w);
  font-size: var(--size_18);
  text-align: center;
  padding: 5px 5px 3px;
  white-space: nowrap;
  border-right: 1px solid var(--color-w);
}
.score:last-child {
  border-right: 0px;
  background: #ff0000;
}

.score.add {
  background: var(--primary);
}

/*公廁上傳圖片*/
.dropzone {
  border: 1px dashed #ced4da;
  padding: 10px;
  min-height: 50px;
}
.dropzone .dz-message {
  margin: 0.3rem 0;
  color: var(--text);
}
.dropzone .dz-preview {
  margin: 5px;
}
.dropzone .dz-preview .dz-details {
  padding: 1rem 0.5rem;
}
.dropzone .dz-preview .dz-details .dz-size {
  font-size: var(--size_15);
  margin-bottom: 0.5em;
}
.dropzone .dz-preview .dz-image {
  width: 80px;
  height: 80px;
}

.popup-upload .dz-preview .dz-details, .popup-upload .dz-preview .dz-progress {
  display: none;
}

@media (max-width: 768px) {
  .sidebar-offcanvas {
    display: none;
  }
}
/*------------------------
入口頁
-------------------------*/
/*共用標題*/
.hp-title {
  position: relative;
  font-size: var(--size_30);
  color: var(--color-w);
  font-weight: normal;
  padding: 10px;
}
.hp-title span {
  display: block;
  font-weight: normal;
  font-size: var(--size_14);
}
.hp-title::before, .hp-title::after {
  content: "";
  position: absolute;
  top: 0px;
  left: 0px;
  background: var(--color-w);
}
.hp-title::before {
  width: 16px;
  height: 1px;
}
.hp-title::after {
  height: 15px;
  width: 1px;
}

/*專區*/
.administration {
  margin-top: 10px;
  text-decoration: none;
  background: transparent linear-gradient(129deg, #1D416A 0%, #1D416A 100%) 0% 0%;
  display: block;
  text-align: center;
  padding: 30px 20px 20px;
  opacity: 0.74;
  border-radius: 15px;
  position: relative;
}
.administration p {
  padding-top: 0px;
  color: var(--color-w);
  font-size: var(--size_21);
  line-height: 1.2;
}
.administration::before {
  content: "";
  position: absolute;
  top: 5px;
  left: 0px;
  right: 0px;
  margin: auto;
  width: 100%;
  height: 14px;
  background: transparent radial-gradient(closest-side at 50% 50%, var(--color-w) 0%, rgba(128, 128, 128, 0) 100%) 0% 0% no-repeat padding-box;
  opacity: 0.19;
}

.administration.active, .administration:hover {
  background: transparent linear-gradient(1549deg, #247EC7 0%, #7B5ABA 100%) 0% 0%;
  -webkit-box-shadow: 0px 0px 9px rgba(255, 255, 255, 0.8274509804) !important;
          box-shadow: 0px 0px 9px rgba(255, 255, 255, 0.8274509804) !important;
}

/*welcome*/
.welcome-wrapper {
  margin-bottom: 3%;
  padding: 10px;
  opacity: 0.9;
}
.welcome-wrapper .welcome {
  margin-left: 65%;
  padding-left: 20px;
  border-left: 1px solid rgba(255, 255, 255, 0.8);
}
.welcome-wrapper p {
  color: var(--color-w);
  margin-bottom: 0px;
  font-size: 52px;
  line-height: 1;
}
.welcome-wrapper p:nth-child(2) {
  font-size: 84px;
  font-weight: bolder;
}
.welcome-wrapper p:last-child {
  font-size: var(--size_18);
}
.welcome-wrapper small {
  display: block;
  font-size: var(--size_15);
  color: var(--color-w);
}

/*最新公告*/
.news-wrapper {
  position: relative;
}
.news-wrapper .megaphone {
  position: relative;
}
.news-wrapper .megaphone::before {
  content: "";
  position: absolute;
  left: 0px;
  top: 0px;
  width: 34px;
  height: 36px;
  background: url(/esms/Scripts/images/icon-notice-megaphone-w.svg) no-repeat top center;
}
.news-wrapper .date {
  padding-left: 50px;
}
.news-wrapper .more {
  color: var(--color-w);
  font-size: var(--size_18);
  position: absolute;
  top: 10%;
  right: 10px;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
  z-index: 10;
}
.news-wrapper .more:hover {
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
}
.news-wrapper .news-list {
  padding: 30px 5%;
  border-radius: 15px;
  background: rgba(29, 65, 106, 0.8);
  color: var(--color-w);
}
.news-wrapper .news-list .item {
  border-bottom: 1px solid rgba(255, 255, 255, 0.23);
  padding: 12px 0;
}
.news-wrapper .news-list .item:hover {
  -webkit-transform: scale(1.03);
          transform: scale(1.03);
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
  background: rgba(36, 126, 199, 0.24);
}
.news-wrapper .news-list .item:last-child {
  border-bottom: 0px;
}
.news-wrapper .news-list [class*=col] {
  -ms-flex-item-align: center;
      -ms-grid-row-align: center;
      align-self: center;
}
.news-wrapper .news-list .yaer {
  font-size: var(--size_15);
  opacity: 0.8;
}
.news-wrapper .news-list .month, .news-wrapper .news-list .day {
  font-size: var(--size_33);
}
.news-wrapper .news-list .month::after {
  content: "⁄";
  padding: 0 10px;
  font-weight: lighter;
  opacity: 0.3;
}
.news-wrapper .news-list a {
  -webkit-transition: all 0s ease-in-out;
  transition: all 0s ease-in-out;
}
.news-wrapper .news-list a img[src*=download] {
  opacity: 0.6;
}
.news-wrapper .news-list a:hover {
  opacity: 1;
  padding: 11px 10px;
}
.news-wrapper .news-list a[data-toggle=modal] {
  font-size: var(--size_22);
  color: var(--color-w);
}
.news-wrapper .news-list a[data-toggle=modal] .title {
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  height: calc(1 * var(--size_20) + 1.5);
  margin-bottom: 5px;
}
.news-wrapper .news-list a[data-toggle=modal] .context {
  font-size: var(--size_15);
  opacity: 0.7;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  height: calc(1 * var(--size_16) + 1.5);
}

/*聯繫窗*/
.hp-contact {
  margin-top: 10px;
  padding: 20px 5%;
  background: rgba(65, 38, 109, 0.48);
  border-radius: 15px;
  color: var(--color-w);
  font-size: var(--size_17);
}
.hp-contact [class*=col] {
  -ms-flex-item-align: center;
      -ms-grid-row-align: center;
      align-self: center;
}
.hp-contact .col-auto:not(:last-child, :first-child) {
  border-right: 1px solid rgba(255, 255, 255, 0.12);
}
.hp-contact .col-auto a {
  color: var(--color-w);
}
.hp-contact .col-auto p {
  opacity: 0.6;
  font-size: var(--size_15);
}
.hp-contact .title {
  font-size: var(--size_22);
}
.hp-contact .title .company {
  display: block;
  font-size: var(--size_15);
}

.password-wrapper .password-content {
  background: rgba(29, 65, 106, 0.8);
  padding: 20px 5%;
  border-radius: 15px;
}
.password-wrapper .password-content .text-muted {
  color: #ffb0b0 !important;
}
.password-wrapper .password-content .form-group label {
  font-size: var(--size_16);
  color: var(--color-w);
  margin-bottom: 0.5rem;
}
.password-wrapper .password-content .form-group input {
  line-height: 1.5;
  padding: 10px;
  font-size: 16px;
  height: 45px;
}
.password-wrapper .password-content .form-group .redo {
  -ms-flex-item-align: end;
      align-self: flex-end;
}
.password-wrapper .password-content .form-group .redo .fa-redo {
  color: var(--color-w);
  font-size: var(--size_20);
  line-height: 1.2;
}
.password-wrapper .password-content .note {
  border-top: 1px dashed rgba(204, 204, 204, 0.5);
  padding: 1rem;
  margin-top: 1rem;
}
.password-wrapper .password-content .note h6 {
  font-weight: bolder;
}
.password-wrapper .password-content .note ul li, .password-wrapper .password-content .note h6, .password-wrapper .password-content .note p {
  color: var(--color-w);
  opacity: 0.75;
}

@media (max-width: 1440px) {
  /*專區*/
  .administration .img-fluid {
    max-width: 38%;
  }
  /*welcome*/
  .welcome-wrapper .welcome {
    margin-left: 70%;
  }
  .welcome-wrapper .welcome p {
    color: var(--color-w);
    font-size: 30px;
  }
  .welcome-wrapper .welcome p:nth-child(2) {
    font-size: 65px;
  }
  .welcome-wrapper .welcome p:last-child {
    font-size: var(--size_18);
  }
  .hp-contact [class*=col] {
    padding: 0 5px;
  }
}
@media (max-width: 1024px) {
  .administration {
    padding: 30px 10px 20px;
  }
}
/*------------------------
dashboard
-------------------------*/
.dashboard.bg-w {
  padding: 30px 25px;
  border-radius: 15px;
  margin-bottom: 10px;
}

.dashboard.taiwanmap {
  background: rgba(43, 60, 146, 0.44);
  border: 1px solid #ffffff;
}
.dashboard.taiwanmap .dashboard-title {
  color: var(--color-w);
}

.dashboard #Spiderweb {
  height: 355px;
}
.dashboard #rateArea {
  height: 280px;
}
.dashboard #toiletTreemap {
  height: 420px;
}
.dashboard #barCity {
  height: 305px;
}
.dashboard #barManagement {
  height: 195px;
}
.dashboard .month-range {
  height: 30px;
}
.dashboard .btn-search {
  width: 38px;
  height: 38px;
  line-height: 1.3;
  margin-left: -0.5rem;
}
.dashboard .btn-search .fa-search {
  font-size: var(--size_22);
}
.dashboard .counter.controlled {
  font-size: var(--size_48);
}
.dashboard .counter-box {
  width: 50%;
  -ms-flex-item-align: center;
      -ms-grid-row-align: center;
      align-self: center;
}
.dashboard .counter-box .counter-title {
  font-weight: 700;
  font-size: var(--size_15);
}
.dashboard .counter-box .counter-title span {
  opacity: 0.4;
  margin-left: 0.1rem;
}
.dashboard .counter-box .counter {
  font-size: var(--size_40);
}
.dashboard .counter-box .counter::after {
  content: "%";
  font-size: 21px;
}
.dashboard .nav-pills {
  position: absolute;
  top: 20px;
  right: 20px;
  background: #efefef;
  border-radius: 30px;
}
.dashboard .nav-pills .nav-link {
  border-radius: 30px;
  font-size: var(--size_15);
}
.dashboard .nav-pills .nav-link.active {
  background: transparent -webkit-gradient(linear, left top, left bottom, from(#F3A367), to(#DD4D6D)) 0% 0% no-repeat padding-box;
  background: transparent linear-gradient(180deg, #F3A367 0%, #DD4D6D 100%) 0% 0% no-repeat padding-box;
}
.dashboard .nav-pills .nav-link:focus {
  background: transparent -webkit-gradient(linear, left top, left bottom, from(#F3A367), to(#DD4D6D)) 0% 0% no-repeat padding-box;
  background: transparent linear-gradient(180deg, #F3A367 0%, #DD4D6D 100%) 0% 0% no-repeat padding-box;
  color: var(--color-w);
}
.dashboard .tab-pane .card {
  border: 0px;
  background: #F2F2F2;
}
.dashboard .tab-pane .card .card-title {
  font-size: var(--size_14);
  margin-bottom: 5px;
}
.dashboard .tab-pane .card .card-body {
  padding: 10px;
}
.dashboard .tab-pane .card img {
  width: 40px;
  float: left;
  margin-right: 5px;
}
.dashboard .tab-pane .card .counter {
  font-size: var(--size_30);
}
.dashboard .ratecounter {
  margin: 30px 0 15px;
}
.dashboard .ratecounter .counter-box .rate {
  margin-top: -8px;
  color: #868686;
  font-size: var(--size_13);
}
.dashboard .ratecounter .counter-box .rate span {
  font-weight: bold;
  color: var(--text);
}
.dashboard .ratecounter .counter-box .counter::after {
  content: "座";
  font-size: 14px;
}

@media (max-width: 1440px) {
  .dashboard.bg-w {
    padding: 30px 15px;
  }
  .dashboard.bg-w .tab-pane .card .counter {
    font-size: var(--size_24);
  }
}
.table-reply thead th {
  vertical-align: middle;
  line-height: 1;
  white-space: nowrap;
}
.table-reply small {
  opacity: 0.7;
}
.table-reply [rowspan] {
  background: #dee8f0;
}
.table-reply [rowspan] label {
  font-size: var(--size_18);
  color: #52597f;
}
.table-reply .img-fluid {
  max-height: 80px;
}
.table-reply .img-fluid:hover {
  opacity: 0.8;
  border: 1px dashed var(--text);
}

.lists {
  list-style: none;
  padding-left: 15px;
}
.lists li:before {
  content: "\f058";
  color: var(--primary);
  font-weight: bolder;
  font-family: "Font Awesome 5 pro";
  margin-right: 0.3rem;
}

.pass-box {
  text-align: center;
}
.pass-box .fa-check-circle, .pass-box .fa-times-circle {
  font-size: var(--size_40);
  color: var(--primary);
}
.pass-box h5 {
  font-size: var(--size_20);
  color: var(--primary);
}

.pass-box.return h5, .pass-box.return .fa-times-circle {
  color: var(--danger);
}

/*巡檢紀錄管理 切換*/
.main-content {
  position: relative;
}

.nav-pills.management {
  position: absolute;
  right: 40px;
  top: 40px;
  background: #ffe9e1;
  border-radius: 30px;
  z-index: 2;
}
.nav-pills.management .nav-link {
  font-size: var(--size_17);
  color: var(--secondary);
  border-radius: 30px;
}
.nav-pills.management .nav-link:hover, .nav-pills.management .nav-link:focus, .nav-pills.management .nav-link :active {
  background: rgba(245, 127, 52, 0.21);
  color: var(--secondary);
}
.nav-pills.management .nav-link.active {
  background: transparent linear-gradient(144deg, #F3A367 0%, #DD4D6D 100%) 0% 0% no-repeat padding-box;
  color: var(--color-w);
}

.category-list td a {
  font-size: var(--size_16);
  color: var(--text);
}

/*************
最新公告
***************/
.notice .megaphone, .download-table .megaphone {
  position: relative;
}
.notice .megaphone::before, .download-table .megaphone::before {
  content: "";
  position: absolute;
  left: 0px;
  top: 0px;
  width: 34px;
  height: 36px;
  background: url(/esms/Scripts/images/icon-notice-megaphone.svg) no-repeat top center;
}
.notice .date, .download-table .date {
  padding-left: 50px;
}
.notice .yaer, .download-table .yaer {
  font-size: var(--size_15);
  opacity: 0.8;
  line-height: 1.2;
  color: var(--primary);
}
.notice .month, .notice .day, .download-table .month, .download-table .day {
  font-size: var(--size_22);
  font-weight: bolder;
  opacity: 0.8;
  color: var(--primary);
}
.notice .month::after, .download-table .month::after {
  content: "⁄";
  padding: 0 10px;
  font-weight: lighter;
}

.notice {
  margin-bottom: 2rem;
  border-top: 3px solid #626262;
  padding-top: 1rem;
}
.notice .card {
  margin-bottom: 0.5rem;
  border: 0px;
  background: var(--colo-w);
  border-radius: 0px;
}
.notice .card .card-header {
  padding: 0rem;
  margin-bottom: 0px;
  background: var(--colo-w);
  border: 0px;
}
.notice .card .card-header a {
  padding: 0.5rem 2%;
  color: var(--dark);
  border-bottom: 1px dashed var(--light);
}
.notice .card .card-header a:hover:not([aria-expanded=true]) {
  background: var(--bg-lb);
}
.notice .card .card-header a:hover:not([aria-expanded=true]) .month, .notice .card .card-header a:hover:not([aria-expanded=true]) .day, .notice .card .card-header a:hover:not([aria-expanded=true]) .yaer, .notice .card .card-header a:hover:not([aria-expanded=true]) .title {
  color: var(--primary);
}
.notice .card .card-header a .title {
  font-size: var(--size_18);
  -ms-flex-item-align: center;
      -ms-grid-row-align: center;
      align-self: center;
  padding-right: 30px;
}
.notice .card .card-header a::after {
  content: "\f077";
  font-family: "Font Awesome 5 Pro";
  float: right;
  margin-right: 10px;
  color: var(--colo-w);
  font-size: var(--size_20);
  -ms-flex-item-align: center;
      -ms-grid-row-align: center;
      align-self: center;
  opacity: 0.4;
}
.notice .card .card-header a[aria-expanded=true] {
  background: var(--primary);
  color: var(--color-w);
  border-bottom: 0px;
}
.notice .card .card-header a[aria-expanded=true] .megaphone::before {
  background: url(/esms/Scripts/images/icon-notice-megaphone-w.svg) no-repeat top center;
}
.notice .card .card-header a[aria-expanded=true] .yaer, .notice .card .card-header a[aria-expanded=true] .month, .notice .card .card-header a[aria-expanded=true] .day {
  opacity: 0.6;
  color: var(--color-w);
}
.notice .card .card-header a[aria-expanded=true]::after {
  content: "\f078";
  color: var(--color-w);
}
.notice .card .card-body.post-content {
  font-size: var(--size_16);
  line-height: 1.8;
}
.notice .card .card-body.post-content h2 {
  font-size: var(--size_24);
}
.notice .card .card-body.post-content h3 {
  font-size: var(--size_20);
  font-weight: 600;
}
.notice .card .card-body.post-content .download {
  margin-top: 0.2rem;
}
.notice .card .collapse.show .card-body {
  padding: 2%;
  border: 1px solid var(--primary);
}

/*************
檔案下載
***************/
.download-table .megaphone {
  text-align: center;
}
.download-table .megaphone::before {
  background-position: center center;
  top: calc(50% - 18px);
  left: calc(50% - 17px);
}
.download-table .table thead th {
  white-space: nowrap;
}
.download-table .table thead th:first-child {
  width: 5%;
}
.download-table .table thead th:nth-child(2) {
  width: 12%;
}
.download-table .table th:first-child, .download-table .table td:first-child {
  text-align: center;
}

@media (max-width: 768px) {
  .notice .megaphone::before {
    background-size: 60%;
  }
  .notice .date {
    padding-left: 30px;
  }
}
/*.nav-tabs*/
.nav-tabs.statisticsTab {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  background: var(--color-w);
  margin-bottom: 0.3rem;
  padding: 0.2rem;
  border-bottom: 0px;
}
.nav-tabs.statisticsTab .nav-link {
  font-size: var(--size_16);
  color: var(--text);
  border-radius: 0px;
  border: 0px;
  border-bottom: 3px solid var(--color-w);
}
.nav-tabs.statisticsTab .nav-link:hover, .nav-tabs.statisticsTab .nav-link:focus {
  color: var(--text);
  border-bottom: 3px solid #a0a0a0;
}
.nav-tabs.statisticsTab .nav-link.active {
  background: var(--color-w);
  color: var(--purple);
  border-bottom: 3px solid var(--purple);
}

/*空地空屋工地巡檢處數統計*/
.statistics-cards .card {
  padding: 0px;
  margin: 0.3rem;
}
.statistics-cards .card-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  background: var(--primary);
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.statistics-cards .card-header .card-title {
  color: var(--color-w);
}
.statistics-cards .card-header .card-title .badge-light {
  background: rgba(255, 255, 255, 0.84);
  color: var(--primary);
}
.statistics-cards .card-header .btn-city {
  color: var(--color-w);
  font-size: var(--size_22);
}
.statistics-cards .card-body {
  text-align: center;
}
.statistics-cards .card-body .card-text {
  font-size: var(--size_24);
  margin-bottom: 0.3rem;
  font-weight: bolder;
}
.statistics-cards .card-body .subtitle {
  font-size: var(--size_14);
}
.statistics-cards {
  /*總數*/
}
.statistics-cards .card.total {
  border-radius: 0px;
  border: 0px;
  border-bottom: 1px solid #e0e0e0;
  margin-top: 2rem;
}
.statistics-cards .card.total .card-header {
  background: var(--purple);
  border-radius: 0px;
  border: 0px;
  border-bottom: 2px solid var(--purple);
  color: var(--color-w);
}
.statistics-cards .card.total .card-header .card-title {
  color: var(--color-w);
  font-weight: bolder;
}
.statistics-cards .card.total .card-header span {
  font-size: var(--size_20);
  color: var(--purple);
}
.statistics-cards .card.total .card-body {
  padding: 0.3rem;
  border-radius: 0px;
  background: #eef2ff;
}
.statistics-cards .card.total .card-body .col {
  border-right: 1px solid #cccbcb;
}
.statistics-cards .card.total .card-body .card-text {
  font-size: var(--size_30);
  color: var(--purple);
  margin-bottom: 0px;
}
.statistics-cards .card.total .card-body .subtitle {
  font-size: var(--size_18);
}

.tooltip-inner {
  text-align: left;
}

/*==================
全國公廁民眾評鑑地圖
==================*/
.toilet-filter #daterangepicker-map {
  border-radius: 30px;
  padding-left: 2.8rem;
}

.ratingmap .taiwan-mapbox {
  height: 460px;
}
.ratingmap .taiwan-mapbox svg {
  max-width: 370px;
  left: calc(50% - 185px);
  margin: auto;
}
.ratingmap .taiwan-mapbox .land.rating {
  fill: #8a62d1;
}
.ratingmap .taiwan-mapbox .land.rating.active {
  fill: #222f6f;
  stroke-linejoin: round;
}
.ratingmap .taiwan-mapbox {
  /* 各星級的顏色定義 */
}
.ratingmap .taiwan-mapbox .land.rating-4 {
  fill: #7048ba;
}
.ratingmap .taiwan-mapbox .land.rating-3 {
  fill: #8a62d1;
}
.ratingmap .taiwan-mapbox .land.rating-2 {
  fill: #9c73e6;
}
.ratingmap .taiwan-mapbox .land.rating-1 {
  fill: #b998f2;
}
.ratingmap .map-buttons {
  padding: 30px 0 0;
  text-align: center;
}
.ratingmap .map-buttons .rating-button {
  padding: 0.3rem 0.1rem;
  font-size: var(--size_13);
  color: var(--color-w);
}
.ratingmap .map-buttons [data-rating="4"] .fa-circle {
  color: #8048E5;
}
.ratingmap .map-buttons [data-rating="3"] .fa-circle {
  color: #A06CFF;
}
.ratingmap .map-buttons [data-rating="2"] .fa-circle {
  color: #B692F7;
}
.ratingmap .map-buttons [data-rating="1"] .fa-circle {
  color: #BEA9E3;
}

/*深色版dashboard共用*/
.dashboard-sub {
  margin: 0.3rem auto;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  color: var(--color-w);
  text-align: center;
  padding: 0.3rem 1.5rem;
  border-radius: 50px;
  border: 1px solid #ffffff;
  font-size: var(--size_16);
}

.bg-ddb.dashboard {
  padding: 30px 25px;
  border-radius: 15px;
  margin-bottom: 10px;
}
.bg-ddb.dashboard h2, .bg-ddb.dashboard h4, .bg-ddb.dashboard .controlled {
  color: var(--color-w);
}
.bg-ddb.dashboard h4 {
  font-weight: bold;
  font-size: var(--size_20);
}

.bg-dddb {
  background: #1D416A;
}

.bg-dddb.dashboard {
  margin-bottom: 0.5rem;
  border-radius: 15px;
  padding: 30px 25px;
}
.bg-dddb.dashboard .counter.controlled {
  font-size: var(--size_42);
  color: var(--color-w);
}
.bg-dddb.dashboard .dashboard-title {
  color: var(--color-w);
}
.bg-dddb.dashboard label[for=subsidyNationwide] .counter.controlled {
  font-size: var(--size_48);
}
.bg-dddb.dashboard table.dataTable td.bg-ddb:hover, .bg-dddb.dashboard table.dataTable tr:hover td.bg-ddb {
  background: #1D416A !important;
}

.dashboard {
  position: relative;
  overflow: hidden;
}
.dashboard .b-l-dashed {
  border-left: 1px solid #3F7793;
}
.dashboard {
  /*指標*/
}
.dashboard .mark {
  position: absolute;
  bottom: -60px;
  right: -60px;
  width: 140px;
  height: 140px;
  border-radius: 50%;
  background: transparent linear-gradient(315deg, #9674cf 0%, #4D3577 100%) 0% 0% no-repeat padding-box;
}
.dashboard .mark span {
  font-size: var(--size_38);
  font-weight: bolder;
  color: var(--color-w);
  position: absolute;
  top: 12%;
  left: 18%;
}
.dashboard .mark.excellent {
  background: transparent linear-gradient(315deg, #9674cf 0%, #4D3577 100%) 0% 0% no-repeat padding-box;
}
.dashboard .mark.low {
  background: transparent linear-gradient(315deg, #9a0000 0%, #CC595F 100%) 0% 0% no-repeat padding-box;
}
.dashboard .list-inline-item {
  color: var(--color-w);
}

/*平均滿意度*/
.counter::after {
  font-size: 50%;
}

.counter.average::after {
  content: "顆星";
}

/*平均結案時間*/
.counter.day::after {
  content: "天";
}

/*======================
評鑑性別比率
========================*/
.gender {
  border-bottom: 1px dashed rgba(255, 255, 255, 0.38);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.gender .img-fluid {
  max-width: 80%;
}

/*給#Circleround百分比共用*/
[id*=Circle] svg + .progressbar-text::after {
  content: "%";
  font-size: 60%;
}

/*給#genderCircleround一個範圍*/
[id*=genderCircleround] {
  margin: 15px 20px;
  width: 86px;
  height: 86px;
  position: relative;
}
[id*=genderCircleround] .progressbar-text {
  top: 37% !important;
  left: 45% !important;
  -webkit-transform: translate(-37%, -45%) !important;
          transform: translate(-37%, -45%) !important;
}
[id*=genderCircleround] .sex {
  position: absolute;
  bottom: 24%;
  left: 50%;
  padding: 0px;
  margin: 0px;
  -webkit-transform: translate(-50%, -24%);
          transform: translate(-50%, -24%);
}
[id*=genderCircleround] .sex.male {
  color: #8DD4F4;
}
[id*=genderCircleround] .sex.female {
  color: #F4A1D4;
}
[id*=genderCircleround] .sex.custom {
  color: #FDD975;
}

.dashboard.average {
  height: 225px;
  max-height: 225px;
}

.dashboard.genderCircleround {
  height: 420px;
  max-height: 420px;
}

/*highcharts公廁類別總計+場域總計高度*/
[id*=typeTotal], [id*=areaTotal] {
  height: 280px;
  max-height: 280px;
  margin: 0 auto;
}

/*======================
類別總計
========================*/
#barRating {
  height: 135px;
  max-height: 135px;
  margin: 0 auto;
}

.rating-basic-single + .select2-container--default .select2-selection--single {
  height: 35px;
  border-radius: 30px;
  background: rgba(255, 255, 255, 0.1);
  border-color: var(--color-w);
}
.rating-basic-single + .select2-container--default .select2-selection--single .select2-selection__rendered {
  line-height: 35px;
  font-size: var(--size_16);
  padding: 0 1rem;
  color: var(--color-w);
}
.rating-basic-single + .select2-container--default .select2-selection--single::after {
  color: var(--color-w);
}

/*===================
通報次數總計
====================*/
/*總計標題*/
.chart-pie-title {
  text-align: center;
}
.chart-pie-title span:first-child {
  font-size: var(--size_30);
}

.polt-text b {
  font-size: var(--size_24);
}

.highcharts-breadcrumbs-button text, .highcharts-breadcrumbs-separator text {
  fill: #FFFFFF !important;
  color: #FFFFFF !important;
}

.highcharts-breadcrumbs-button:hover rect {
  fill: none !important;
  stroke: none !important;
}

/*全國列管統計dashboard*/
.vacant-l .counter.controlled {
  font-size: var(--size_38);
}

#classified-ministries [data-highcharts-chart] {
  height: 450px;
}

.bg-warring {
  background: #D0585E !important;
}

/*髒亂點地圖*/
.bg-dirtymap {
  width: 100%;
  height: 470px;
  max-height: 470px;
  background: url(/esms/Scripts/images/bg-map.png) no-repeat;
  background-position: center;
  margin: 0.5rem 0;
}
.bg-dirtymap .point {
  width: 20px;
  height: 20px;
  border-radius: 50px;
  background: rgba(104, 184, 58, 0.85);
  border: 2px solid;
}
.bg-dirtymap .point.lowrisk {
  background: rgba(104, 184, 58, 0.7);
  border-color: var(--green);
}
.bg-dirtymap .point.warning {
  background: rgba(220, 53, 69, 0.7);
  border-color: var(--danger);
}
.bg-dirtymap .point.attention {
  background: rgba(252, 157, 24, 0.7);
  border-color: var(--orange);
}

.dirtymap-info .dirty-header {
  background: #124C67;
  border-radius: 15px 15px 0 0;
  color: var(--color-w);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.dirtymap-info .dirty-header h5 {
  color: var(--color-w);
  margin-bottom: 0px;
  padding: 0rem 0.5rem;
  font-size: var(--size_16);
  line-height: 2.5;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  height: calc(var(--size_16) * 2.5 * 1);
}
.dirtymap-info .dirty-header .headertitle {
  color: var(--color-w);
  line-height: 2.5;
  padding: 0rem 0.5rem;
  font-size: var(--size_16);
  white-space: nowrap;
}
.dirtymap-info .dirty-header .headertitle.warning {
  background: transparent linear-gradient(139deg, #F3A367 0%, #DD4D6D 100%) 0% 0% no-repeat padding-box;
  border-radius: 15px 0 0 0;
}
.dirtymap-info .dirty-header .headertitle.lowrisk {
  background: transparent linear-gradient(139deg, #5cce20 0%, #20af20 100%) 0% 0% no-repeat padding-box;
  border-radius: 15px 0 0 0;
}
.dirtymap-info .dirty-header .headertitle.attention {
  background: transparent linear-gradient(139deg, #fad24c 0%, #ffba00 100%) 0% 0% no-repeat padding-box;
  border-radius: 15px 0 0 0;
}
.dirtymap-info .dirty-body table {
  width: 100%;
}
.dirtymap-info .dirty-body table td {
  padding: 0.3rem 0.5rem;
}
.dirtymap-info .dirty-body table td:nth-child(odd) {
  font-weight: bolder;
  width: 22%;
}
.dirtymap-info .dirty-body table tr:not(:last-child) {
  border-bottom: 1px solid #ebebeb;
}

/*中央行政機關填報頻率*/
.bg-w-o20.dashboard {
  border-radius: 15px;
  background: rgba(255, 255, 255, 0.15);
  padding: 15px;
  color: var(--color-w);
  margin-bottom: 10px;
  position: relative;
}
.bg-w-o20.dashboard .controlled {
  font-size: var(--size_33);
  color: var(--color-w);
  margin-bottom: 10px;
}
.bg-w-o20.dashboard .subtitle {
  background: #1D416A;
  border-radius: 50px;
  position: absolute;
  top: -0.35rem;
  left: 1rem;
  padding: 0.1rem 1rem;
}
.bg-w-o20.dashboard {
  /*公廁工程中央補助決標總金額 進度*/
}
.bg-w-o20.dashboard .schedule [class*=col] {
  padding: 15px;
}
.bg-w-o20.dashboard .schedule .behind, .bg-w-o20.dashboard .schedule .ahead {
  text-align: center;
  font-size: var(--size_28);
}
.bg-w-o20.dashboard .schedule .behind {
  background: transparent -webkit-gradient(linear, left top, left bottom, from(#F3A367), to(#DD4D6D)) 0% 0% no-repeat padding-box;
  background: transparent linear-gradient(180deg, #F3A367 0%, #DD4D6D 100%) 0% 0% no-repeat padding-box;
}
.bg-w-o20.dashboard .schedule .ahead {
  background: transparent linear-gradient(139deg, #5cce20 0%, #20af20 100%) 0% 0% no-repeat padding-box;
}

.table-dark.report-frequency th {
  text-align: center;
  border: 1px solid var(--text);
}
.table-dark.report-frequency thead tr:not(:first-child) th {
  background: #343a40;
  color: var(--color-w);
}
.table-dark.report-frequency td {
  background: var(--l-g);
  color: #000000;
  border: 1px solid var(--color-w);
  text-align: right;
}
.table-dark.report-frequency th:nth-child(n+6), .table-dark.report-frequency th:nth-child(4), .table-dark.report-frequency tr:last-child th {
  width: 15%;
}
.table-dark.report-frequency tfoot tr:first-child td {
  border-top: 2px solid #185B7B;
}
.table-dark.report-frequency tfoot td {
  font-size: var(--size_19);
  font-weight: bold;
  padding: 1rem 12px;
}

@media (max-width: 1680px) {
  .bg-ddb.dashboard .counter.controlled {
    font-size: var(--size_28);
  }
  .bg-ddb.dashboard h4 {
    font-size: var(--size_16);
  }
  .bg-ddb.dashboard .img-fluid {
    max-width: 27%;
  }
  .gender [id*=genderCircleround] {
    margin: 5px;
  }
  .gender .img-fluid {
    max-width: 35%;
  }
  #areaTotal {
    max-width: 280px;
  }
}
@media (max-width: 1440px) {
  .dashboard .mark {
    bottom: -70px;
  }
  .dashboard .counter.controlled {
    font-size: var(--size_20);
  }
  .bg-ddb.dashboard .counter.controlled {
    font-size: var(--size_22);
  }
  .ratingmap .taiwan-mapbox {
    height: 430px;
  }
  .ratingmap .taiwan-mapbox svg {
    max-width: 340px;
    left: calc(50% - 170px);
  }
  .dashboard.average {
    height: 200px;
    max-height: 200px;
  }
  .dashboard.genderCircleround {
    height: 400px;
    max-height: 400px;
  }
  .gender [id*=genderCircleround] {
    margin: 7px 2px;
  }
  [id*=areaTotal] {
    max-width: 250px;
  }
  .bg-ddb.dashboard {
    padding: 20px;
  }
  .bg-ddb.dashboard h4 {
    font-size: var(--size_14);
  }
  /*總計標題*/
  .chart-pie-title {
    text-align: center;
  }
  .chart-pie-title span:first-child {
    font-size: var(--size_20);
  }
  .bg-dirtymap {
    height: 435px;
    max-height: 435px;
  }
  .dirtymap-info .dirty-header h5 {
    font-size: var(--size_13);
    padding: 0 0.5rem;
  }
  .dirtymap-info .dirty-body table td {
    font-size: var(--size_13);
    padding: 0.3rem;
  }
}
@media (max-width: 1279px) {
  .gender .img-fluid {
    display: none;
  }
  #areaTotal {
    max-width: 260px;
  }
  .bg-ddb.dashboard .img-fluid {
    max-width: 60%;
  }
}
@media (max-width: 996px) {
  .gender .img-fluid {
    display: block;
    max-width: 50%;
  }
  .dashboard.genderCircleround, .dashboard.average {
    height: auto;
    max-height: 100%;
  }
  .bg-ddb.dashboard h4 {
    font-size: var(--size_20);
  }
  .dashboard .b-l-dashed {
    border-left: 0px solid #3F7793;
  }
}
.controlled.pct::after {
  content: "%";
}

.controlled.pl::after {
  content: "處";
}

.controlled.cases::after {
  content: "件";
}

.controlled.place::after {
  content: "座";
}

/*補助計畫戰情儀表板切換框架*/
.subsidy .dashboard div.dataTables_wrapper div.dataTables_info {
  color: var(--color-w);
}
.subsidy .dashboard .form-check {
  padding-left: 0rem;
  width: 100%;
}
.subsidy .dashboard .form-check input[type=radio] + label, .subsidy .dashboard .form-check label {
  display: block;
  cursor: pointer;
  width: 100%;
  padding: 22px 25px;
  color: var(--color-w);
}
.subsidy .dashboard .form-check input[type=radio] + label::after, .subsidy .dashboard .form-check input[type=radio] + label::before, .subsidy .dashboard .form-check label::after, .subsidy .dashboard .form-check label::before {
  display: none;
}
.subsidy .dashboard .form-check input[type=radio] + label[for=subsidyNationwide] {
  font-size: var(--size_22);
  padding: 40px 25px;
  position: relative;
}
.subsidy .dashboard .form-check input[type=radio]:checked + label, .subsidy .dashboard .form-check input[type=radio]:focus + label, .subsidy .dashboard .form-check label:focus {
  border: 2px solid var(--color-w);
  border-radius: 15px;
  background: transparent linear-gradient(301deg, #F3A367 0%, #DD4D6D 100%) 0% 0% no-repeat padding-box;
}
.subsidy .dashboard .form-check input[type=radio]:checked + label [id*=subsidyCircle] .progress-path, .subsidy .dashboard .form-check input[type=radio]:focus + label [id*=subsidyCircle] .progress-path, .subsidy .dashboard .form-check label:focus [id*=subsidyCircle] .progress-path {
  stroke: #DD4D6D; /* 路径颜色 */
  -webkit-transition: stroke 0.3s ease;
  transition: stroke 0.3s ease; /* 平滑过渡效果 */
}
.subsidy .dashboard .form-check input[type=radio]:checked + label [id*=subsidyCircle] .progressbar-text, .subsidy .dashboard .form-check input[type=radio]:focus + label [id*=subsidyCircle] .progressbar-text, .subsidy .dashboard .form-check label:focus [id*=subsidyCircle] .progressbar-text {
  color: var(--color-w) !important;
}
.subsidy .dashboard .form-check input[type=radio]:checked + label [id*=subsidyCircle] .progressbar-text::after, .subsidy .dashboard .form-check input[type=radio]:focus + label [id*=subsidyCircle] .progressbar-text::after, .subsidy .dashboard .form-check label:focus [id*=subsidyCircle] .progressbar-text::after {
  color: var(--color-w) !important;
}
.subsidy .dashboard .form-check input[type=radio]:checked + label .b-l-dashed, .subsidy .dashboard .form-check input[type=radio]:focus + label .b-l-dashed, .subsidy .dashboard .form-check label:focus .b-l-dashed {
  border-color: rgba(255, 255, 255, 0.28);
}
.subsidy .nav .nav-item:first-child {
  position: relative;
}
.subsidy .nav .nav-item:first-child::before {
  content: "";
  position: absolute;
  right: 0;
  top: 20%;
  background: url(/esms/Scripts/images/icon-dashboard-subsidy-Nationwide.svg);
  width: 142px;
  height: 142px;
  background-repeat: no-repeat;
  z-index: 1;
}
.subsidy .nav-tabs.nav-subsidy-Washroom {
  border: 0px;
}
.subsidy .nav-tabs.nav-subsidy-Washroom .nav-link {
  padding: 1rem 1.5rem;
  background: rgba(29, 65, 106, 0.5);
  border-radius: 15px 15px 0 0;
  border: 0px;
}
.subsidy .nav-tabs.nav-subsidy-Washroom .nav-link .counter.controlled {
  font-size: var(--size_38);
  color: var(--color-w);
}
.subsidy .nav-tabs.nav-subsidy-Washroom .nav-link .construction .counter.controlled {
  font-size: var(--size_20);
}
.subsidy .nav-tabs.nav-subsidy-Washroom .nav-link.active {
  background: #1D416A;
}
.subsidy #nav-toiletcase .bg-dddb.dashboard, .subsidy #nav-toiletsubsidy .bg-dddb.dashboard {
  border-radius: 0 15px 15px 15px;
}
.subsidy .search-box .select2-container--default .select2-selection--single {
  background: none;
  color: var(--color-w);
  font-size: 1.1rem;
  border-radius: 30px;
  border-color: rgba(255, 255, 255, 0.53);
}
.subsidy .search-box .select2-container--default .select2-selection--single .select2-selection__rendered {
  color: var(--color-w);
  padding-left: 1rem;
}

[id*=subsidyCircle] svg {
  display: block;
  width: 65px;
  height: 65px;
}

.cityAccumulatedSubsidy {
  height: 600px;
}

@media (max-width: 1440px) {
  .modal-dark .dashboard .counter.controlled {
    font-size: var(--size_33);
  }
}
.statistics-title {
  background: #20B5AA;
  color: var(--color-w);
  font-size: var(--size_20);
  border-radius: 50px;
  max-width: -webkit-fit-content;
  max-width: -moz-fit-content;
  max-width: fit-content;
  margin: auto;
  padding: 0.5rem 2rem;
  z-index: 10;
  position: absolute;
  left: 0;
  right: 0;
  top: 0px;
}

.statistics {
  padding: 25px 25px 10px;
  border-radius: 15px;
  margin: 20px 0 10px;
  color: var(--color-w);
  height: calc(100% - 10px);
  -ms-flex-line-pack: center;
      align-content: center;
}
.statistics .dashboard-title {
  font-size: var(--size_25);
}
.statistics .counter.controlled {
  font-size: var(--size_48);
  color: var(--color-w);
}
.statistics .type-box {
  color: var(--color-w);
  font-size: var(--size_18);
}
.statistics .type-box .item {
  margin-bottom: 0.3rem;
}
.statistics .type-box .counter.controlled {
  font-size: var(--size_18);
}
.statistics .unit {
  font-size: var(--size_18);
  margin-left: 0.2rem;
}
.statistics .form-row > .col, .statistics .form-row > [class*=col-] {
  -ms-flex-item-align: center;
      -ms-grid-row-align: center;
      align-self: center;
}

@media (max-width: 1560px) {
  .statistics .dashboard-title {
    font-size: var(--size_18);
  }
  .statistics .counter.controlled {
    font-size: var(--size_33);
  }
  .statistics .unit {
    font-size: var(--size_14);
  }
  .statistics .type-box {
    font-size: var(--size_16);
  }
  .statistics .type-box .counter.controlled {
    font-size: var(--size_16);
  }
}
/*=================
新增認養公廁功能
===================*/
/*按鈕*/
.adoption {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-line-pack: center;
      align-content: center;
  margin-bottom: 5px;
}
.adoption .btn-adoption {
  border: 1px solid rgba(66, 137, 195, 0.5);
  background: #E0F1FF;
  border-radius: 5px;
  color: var(--primary);
  padding: 0px 5px 0px;
  height: 38px;
  margin: 0;
  line-height: 38px;
}
.adoption .btn-adoption .fad {
  vertical-align: sub;
}
.adoption .btn-adoption:hover, .adoption .btn-adoption:focus {
  color: var(--color-w);
  -webkit-transform: scale(1);
          transform: scale(1);
  color: var(--primary);
}
.adoption input {
  height: 38px;
  border-radius: 5px 0px 0px 5px;
  border: 1px solid rgba(66, 137, 195, 0.5);
  border-right: 0px;
}

/*單筆*/
.adoption.single .btn-adoption {
  border-radius: 0px 5px 5px 0px;
  border-left: 0px;
  -ms-flex-line-pack: center;
      align-content: center;
}

/*認養公廁資料編輯*/
#adoptionTable th {
  text-align: center;
}
#adoptionTable .input-group.date-range {
  width: 260px;
  margin: auto;
}
#adoptionTable .input-group.date-range .input-group-text {
  padding: 0.375rem 0.3rem;
}
#adoptionTable .bs-select.type {
  width: 330px;
}

/*認養型態說明*/
.adoption-info {
  margin-top: 20px;
  background: #f2f2f2;
  border-radius: 10px;
  padding: 10px 20px;
  width: 100%;
}
.adoption-info:hover {
  background: #f2f2f2;
}
.adoption-info .btncollapse {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.adoption-info .btncollapse::after {
  content: "\10f13a";
  font-family: "Font Awesome 5 Duotone";
  font-size: var(--size_20);
  opacity: 0.8;
  color: #7846b2;
  margin-left: 5px;
}
.adoption-info [aria-expanded=true]::after {
  content: "\10f139";
}
.adoption-info h5 {
  color: #212529;
  margin-bottom: 0px;
}
.adoption-info .card-body {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  grid-row-gap: 5px;
  padding: 10px 0px 0px;
}
.adoption-info .card-body dd {
  width: 80px;
  padding-left: 15px;
}
.adoption-info .card-body dd span {
  padding: 5px 10px;
  border-radius: 5px;
  background: #e0d2f0;
  color: #441f7d;
}
.adoption-info .card-body dt {
  width: calc(33% - 80px);
  color: var(--text);
}

/*批次新增認養公廁*/
#addtoiletModal tr.selected td {
  background: #e0f1ff;
  border-top: 1px solid #ffffff;
  color: var(--primary);
}

@media (max-width: 1440px) {
  /*認養公廁資料編輯*/
  #adoptionTable .bs-select.type {
    width: 220px;
  }
}
@media (max-width: 1024px) {
  #adoptionTable th {
    text-align: center;
  }
  #adoptionTable .input-group.date-range label:first-child + .form-control {
    width: 100% !important;
  }
  #adoptionTable .input-group.date-range .input-group-append {
    display: block;
    width: 100%;
  }
  #adoptionTable .input-group.date-range .input-group-append .input-group-text {
    border: 0px;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    padding: 0rem 0.75rem;
    line-height: 1;
    background: transparent;
  }
  #adoptionTable .input-group.date-range {
    max-width: 100px;
  }
  #adoptionTable .bs-select.type {
    max-width: 120px;
  }
}
.dropzone.picMissings .dz-preview .dz-image {
  width: 120px;
  height: 120px;
}
.dropzone.picMissings .dz-preview .dz-image img {
  width: 100%;
  height: 100%;
}

/*店家巡查執行成果填報*/
.wraplist-search {
  background: #ecf5f7;
  padding: 20px 30px;
  border: 1px dashed var(--primary);
  border-radius: 5px;
  margin-top: 10px;
}
.wraplist-search .searchForm {
  margin: 5px 0 10px;
}
.wraplist-search .removeall,
.wraplist-search .remove {
  background: var(--secondary);
  color: var(--color-w);
  border-color: #f57f34;
}
.wraplist-search .remove {
  border-top-right-radius: 0.25rem !important;
}
.wraplist-search {
  /*select　style*/
}
.wraplist-search .bootstrap-duallistbox-container:not(.moveonselect) select {
  overflow-x: auto;
  height: 300px;
}
.wraplist-search .bootstrap-duallistbox-container:not(.moveonselect) select option {
  font-family: monospace;
  border-bottom: 1px solid #cccccc;
  padding: 10px;
  font-size: var(--size_14);
}
.wraplist-search .bootstrap-duallistbox-container:not(.moveonselect) select option:nth-child(even) {
  background: #efefef;
}
.wraplist-search {
  /*共用*/
}
.wraplist-search .bootstrap-duallistbox-container {
  /*header*/
}
.wraplist-search .bootstrap-duallistbox-container .listbox-header {
  text-align: center;
  background: #6c757d;
  color: var(--color-w);
}
.wraplist-search .bootstrap-duallistbox-container select.form-control {
  height: calc(1.5em + 0.75rem + 2px) !important;
}
.wraplist-search .bootstrap-duallistbox-container label {
  display: inline;
  font-size: var(--size_20);
}
.wraplist-search .bootstrap-duallistbox-container .label-control {
  font-size: var(--size_15);
}
.wraplist-search .bootstrap-duallistbox-container .info {
  font-size: var(--size_16);
  font-weight: bolder;
}
.wraplist-search .bootstrap-duallistbox-container .box1 {
  padding-right: 40px;
  position: relative;
}
.wraplist-search .bootstrap-duallistbox-container .box1::after {
  position: absolute;
  top: 50%;
  right: -1px;
  content: "\f2f1";
  font-family: "Font Awesome 5 pro";
  font-size: var(--size_28);
  font-weight: bolder;
  opacity: 0.4;
  color: #5274bd;
}
.wraplist-search .bootstrap-duallistbox-container {
  /*右側　已選擇巡查店家 style*/
}
.wraplist-search .bootstrap-duallistbox-container .box2 .info {
  color: var(--secondary);
  border: 1px dashed var(--secondary);
  padding: 3px 10px;
  margin-left: 2px;
  border-radius: 20px;
  background: #fff7ec;
}
.wraplist-search .bootstrap-duallistbox-container .box2 label {
  color: var(--secondary);
}
.wraplist-search .bootstrap-duallistbox-container .box2 .removeall {
  display: none;
}
.wraplist-search .bootstrap-duallistbox-container .box2 select {
  background: #fff7ec;
}
.wraplist-search .bootstrap-duallistbox-container .box2 select option:nth-child(even) {
  background: #fff0dc;
}
.wraplist-search {
  /*已選擇巡查店家高度*/
}
.wraplist-search #bootstrap-duallistbox-selected-list_ {
  height: 490px !important;
}

#btnSelectAllChecked, #btnSelectAllCancel {
  color: var(--secondary);
  border-radius: 30px;
  background: #ffe9e1;
  border-color: #ffe9e1;
  margin: 0px;
}
#btnSelectAllChecked.active, #btnSelectAllCancel.active {
  background: transparent linear-gradient(144deg, #F3A367 0%, #DD4D6D 100%) 0% 0% no-repeat padding-box;
  color: var(--color-w);
}

#btnSelectAllChecked {
  border-radius: 30px 0 0 30px;
}

#btnSelectAllCancel {
  border-radius: 0 30px 30px 0;
}

.city-filter-btn {
  border-radius: 2rem;
  padding: 0.25rem 1.5rem;
}
.city-filter-btn.active, .city-filter-btn.active:focus, .city-filter-btn.active:visited, .city-filter-btn.active:active {
  color: var(--color-w) !important;
  background: var(--primary) !important;
  border-color: var(--primary) !important;
  -webkit-box-shadow: none !important;
          box-shadow: none !important;
}
.city-filter-btn#btn-clear-all.active, .city-filter-btn#btn-clear-all.active:focus, .city-filter-btn#btn-clear-all.active:visited, .city-filter-btn#btn-clear-all.active:active {
  background: var(--danger) !important;
  border-color: var(--danger) !important;
  color: var(--color-w) !important;
}

.citybox .region-row {
  margin-top: 5px;
  margin-bottom: 5px;
}

.citybox .form-check-input:checked ~ .form-check-label {
  color: #393939 !important;
}

.citybox .form-check-label {
  font-weight: normal !important;
}

.citybox .form-check {
  margin-right: 30px;
  /* margin-bottom: 8px; */
}

/*==================
菸蒂盒管理地圖介面
==================*/
.CigaretteButtBox {
  position: relative;
  width: 100%;
  height: calc(100vh - 62px);
  min-height: 600px;
  overflow: hidden;
  background: var(--bg-lb);
}
.CigaretteButtBox .btn-close,
.CigaretteButtBox .popup-close, .CigaretteButtBox .btn-collapse {
  background: #B0BEC5;
  border: none;
  font-size: 16px;
  color: #666666;
  cursor: pointer;
  padding: 0;
  width: 32px;
  height: 32px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  border-radius: 50%;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
}
.CigaretteButtBox .btn-close:hover,
.CigaretteButtBox .popup-close:hover, .CigaretteButtBox .btn-collapse:hover {
  background: #90A4AE;
  color: #333333;
}
.CigaretteButtBox .badge {
  padding: var(--size_9) var(--size_12);
  border-radius: 12px;
  font-weight: 500;
  font-size: var(--size_12);
  display: inline-block;
}

.map-layer {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}
.map-layer .map-bg {
  width: 100%;
  height: 100%;
  background: url(/esms/Scripts/images/map-placeholder.jpg) no-repeat center center;
  background-size: cover;
  background: url(/esms/Scripts/images/bg-map.png);
}

.floating-search {
  position: absolute;
  top: var(--size_20);
  left: var(--size_20);
  z-index: 100;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: var(--size_12);
  padding: var(--size_8);
}
.floating-search .search-outter {
  background: var(--color-w);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  border-radius: 50px;
  -ms-flex-line-pack: center;
      align-content: center;
  padding: 0.5rem;
  -webkit-box-shadow: 0 4px 16px rgba(0, 0, 0, 0.25) !important;
          box-shadow: 0 4px 16px rgba(0, 0, 0, 0.25) !important;
}
.floating-search .search-outter .search-input {
  border: none;
  padding: 1rem;
  font-size: var(--size_16);
  width: 300px;
  background: transparent;
  -ms-flex-item-align: center;
      -ms-grid-row-align: center;
      align-self: center;
}
.floating-search .search-outter .search-input:focus {
  -webkit-box-shadow: none;
          box-shadow: none;
  outline: none;
}
.floating-search .search-outter .btn-search {
  background: var(--primary);
  border: none;
  border-radius: 50%;
  width: 40px;
  height: 40px;
  color: var(--color-w);
  cursor: pointer;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
}
.floating-search .search-outter .btn-search:hover {
  background: var(--text);
}
.floating-search .search-outter .btn-search i {
  font-size: var(--size_18);
}
.floating-search .btn-filter {
  background: var(--color-w);
  border: none;
  border-radius: 50px;
  padding: 0.7rem var(--size_20);
  font-size: var(--size_14);
  color: #000000;
  cursor: pointer;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
  white-space: nowrap;
  -webkit-box-shadow: 0 4px 12px rgba(0, 0, 0, 0.22) !important;
          box-shadow: 0 4px 12px rgba(0, 0, 0, 0.22) !important;
}
.floating-search .btn-filter i {
  margin-right: var(--size_8);
}
.floating-search .btn-filter:hover {
  background: var(--bg-lb);
  color: var(--primary);
}
.floating-search .btn-import-link {
  background: var(--color-w);
  border: none;
  border-radius: 50px;
  padding: 0.7rem var(--size_20);
  font-size: var(--size_14);
  color: #000000;
  cursor: pointer;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
  text-decoration: none;
  white-space: nowrap;
  -webkit-box-shadow: 0 4px 12px rgba(0, 0, 0, 0.22) !important;
          box-shadow: 0 4px 12px rgba(0, 0, 0, 0.22) !important;
}
.floating-search .btn-import-link i {
  margin-right: var(--size_8);
}
.floating-search .btn-import-link:hover {
  background: var(--bg-lb);
  color: var(--primary);
  text-decoration: none;
}

.btn-panel-collapse {
  position: absolute;
  bottom: var(--size_20);
  right: var(--size_20);
  z-index: 100;
  width: 48px;
  height: 48px;
  background: var(--color-w);
  border: none;
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  cursor: pointer;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  -webkit-box-shadow: 0 6px 18px rgba(0, 0, 0, 0.3) !important;
          box-shadow: 0 6px 18px rgba(0, 0, 0, 0.3) !important;
}
.btn-panel-collapse i {
  font-size: var(--size_20);
  color: #333333;
  -webkit-transition: -webkit-transform 0.3s ease;
  transition: -webkit-transform 0.3s ease;
  transition: transform 0.3s ease;
  transition: transform 0.3s ease, -webkit-transform 0.3s ease;
}
.btn-panel-collapse:hover {
  background: var(--primary);
  -webkit-box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35) !important;
          box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35) !important;
}
.btn-panel-collapse:hover i {
  color: var(--color-w);
}
.btn-panel-collapse.collapsed i {
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
}

.filter-sidebar {
  position: absolute;
  top: 90px;
  left: -320px;
  width: 320px;
  height: auto;
  background: hsla(0, 0%, 100%, 0.63);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  z-index: 200;
  -webkit-transition: left 0.3s ease;
  transition: left 0.3s ease;
  -webkit-box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3) !important;
          box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3) !important;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  border-radius: 16px;
}
.filter-sidebar.show {
  left: var(--size-20);
  height: auto;
}
.filter-sidebar .filter-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: var(--spacing-4);
  border-bottom: none;
  background: transparent;
}
.filter-sidebar .filter-header h3 {
  font-size: 18px;
  font-weight: 600;
  margin: 0;
  color: #333333;
}
.filter-sidebar .filter-body {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  padding: 0.5rem var(--spacing-5) var(--spacing-5);
  overflow-y: auto;
}
.filter-sidebar .filter-body::-webkit-scrollbar {
  width: 6px;
}
.filter-sidebar .filter-body::-webkit-scrollbar-track {
  background: rgba(255, 255, 255, 0.3);
  border-radius: 3px;
}
.filter-sidebar .filter-body::-webkit-scrollbar-thumb {
  background: rgba(0, 0, 0, 0.2);
  border-radius: 3px;
}
.filter-sidebar .filter-body::-webkit-scrollbar-thumb:hover {
  background: rgba(0, 0, 0, 0.3);
}
.filter-sidebar .filter-body .form-group {
  margin-bottom: var(--spacing-3);
}
.filter-sidebar .filter-body .form-group .filter-label {
  font-size: 14px;
  font-weight: 500;
  margin-bottom: var(--spacing-2);
  display: block;
  color: #666666;
}
.filter-sidebar .filter-body .form-group .select2-container--default .select2-selection--single {
  border: 1px solid #cccccc;
  border-radius: 30px;
}
.filter-sidebar .filter-body .form-group .select2-container--default .select2-selection--single::after {
  opacity: 0.5;
}
.filter-sidebar .filter-body .form-group .select2-container--default .select2-selection--single .select2-selection__rendered {
  height: 35px;
  line-height: 35px;
  padding-left: 15px;
}
.filter-sidebar .filter-body .form-group .select2-container .select2-selection--single {
  height: 35px;
}
.filter-sidebar .filter-body .form-group .filter-select, .filter-sidebar .filter-body .form-group .form-control {
  width: 100%;
  border: none;
  background: var(--white);
  border-radius: 8px;
  padding: var(--spacing-3);
  font-size: 14px;
  color: #333333;
  -webkit-box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
          box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
}
.filter-sidebar .filter-body .form-group .filter-select:focus, .filter-sidebar .filter-body .form-group .form-control:focus {
  outline: none;
  -webkit-box-shadow: 0 2px 6px rgba(0, 0, 0, 0.12);
          box-shadow: 0 2px 6px rgba(0, 0, 0, 0.12);
}
.filter-sidebar .filter-body .category-section {
  margin-top: var(--spacing-4);
}
.filter-sidebar .filter-body .category-section .category-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-bottom: var(--spacing-3);
}
.filter-sidebar .filter-body .category-section .category-header .filter-label {
  font-size: 14px;
  font-weight: 500;
  margin: 0;
  color: #666666;
}
.filter-sidebar .filter-body .category-section .category-header .category-actions {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: var(--spacing-3);
}
.filter-sidebar .filter-body .category-section .category-header .category-actions .link-select,
.filter-sidebar .filter-body .category-section .category-header .category-actions .link-clear {
  font-size: 13px;
  color: #000000;
  text-decoration: none;
  cursor: pointer;
  font-weight: 500;
}
.filter-sidebar .filter-body .category-section .category-header .category-actions .link-select:hover,
.filter-sidebar .filter-body .category-section .category-header .category-actions .link-clear:hover {
  text-decoration: underline;
}
.filter-sidebar .filter-body .category-section .category-header .category-actions .link-clear {
  color: #E74C3C;
}
.filter-sidebar .filter-body .category-section .category-list {
  background: transparent;
  border-radius: 8px;
  padding: var(--spacing-3);
  max-height: 180px;
  overflow-y: auto;
  -webkit-box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
          box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
}
.filter-sidebar .filter-body .category-section .category-list::-webkit-scrollbar {
  width: 6px;
}
.filter-sidebar .filter-body .category-section .category-list::-webkit-scrollbar-track {
  background: #F5F5F5;
  border-radius: 3px;
}
.filter-sidebar .filter-body .category-section .category-list::-webkit-scrollbar-thumb {
  background: #BDBDBD;
  border-radius: 3px;
}
.filter-sidebar .filter-body .category-section .category-list::-webkit-scrollbar-thumb:hover {
  background: #9E9E9E;
}
.filter-sidebar .filter-body .category-section .category-list .form-check.check-likeqnr {
  margin-bottom: var(--spacing-2);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.filter-sidebar .filter-body .category-section .category-list .form-check.check-likeqnr input[type=checkbox]:checked + label:before {
  border-radius: 3px;
}
.filter-sidebar .filter-body .category-section .category-list .form-check.check-likeqnr:last-child {
  margin-bottom: 0;
}
.filter-sidebar .filter-body .category-section .category-list .form-check.check-likeqnr input[type=checkbox] {
  margin-right: var(--spacing-2);
  width: 18px;
  height: 18px;
  cursor: pointer;
}
.filter-sidebar .filter-body .category-section .category-list .form-check.check-likeqnr .form-check-label {
  cursor: pointer;
  font-size: 14px;
  color: #333333;
  margin: 0;
  line-height: 1.4;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.filter-sidebar .filter-body .category-section .category-list .form-check.check-likeqnr.check-purple input[type=checkbox]:checked + label:before {
  background: #5A44C7;
  border-color: #5A44C7;
}
.filter-sidebar .filter-body .category-section .category-list .form-check.check-likeqnr.check-green input[type=checkbox]:checked + label:before {
  background: #0cc252;
  border-color: #0cc252;
}
.filter-sidebar .filter-body .category-section .category-list .form-check.check-likeqnr.check-gray input[type=checkbox]:checked + label:before {
  background: #95A5A6;
  border-color: #95A5A6;
}
.filter-sidebar .filter-body .category-section .category-list .form-check.check-likeqnr.check-orange input[type=checkbox]:checked + label:before {
  background: #E67E22;
  border-color: #E67E22;
}
.filter-sidebar .filter-body .category-section .category-list .form-check.check-likeqnr.check-teal input[type=checkbox]:checked + label:before {
  background: #20B5AA;
  border-color: #20B5AA;
}
.filter-sidebar .filter-body .category-section .category-list .form-check.check-likeqnr.check-blue input[type=checkbox]:checked + label:before {
  background: #3498DB;
  border-color: #3498DB;
}
.filter-sidebar .filter-body .category-section .category-list .form-check.check-likeqnr.check-indigo input[type=checkbox]:checked + label:before {
  background: #335ff0;
  border-color: #335ff0;
}
.filter-sidebar .filter-body .category-section .category-list .form-check.check-likeqnr.check-red input[type=checkbox]:checked + label:before {
  background: #fd6d6d;
  border-color: #fd6d6d;
}
.filter-sidebar .filter-body .category-section .category-list .form-check.check-likeqnr.check-yellow input[type=checkbox]:checked + label:before {
  background: #ffe033;
  border-color: #ffe033;
}
.filter-sidebar .filter-body .category-section .category-list .form-check.check-likeqnr.check-pink input[type=checkbox]:checked + label:before {
  background: #f967a6;
  border-color: #f967a6;
}
.filter-sidebar .filter-body .btn-apply-filter {
  width: 100%;
  margin-top: var(--spacing-4);
  background: #4289C3;
  color: var(--white);
  border: none;
  padding: var(--spacing-3);
  font-size: 16px;
  border-radius: 8px;
  font-weight: 500;
  cursor: pointer;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
  -webkit-box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
          box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}
.filter-sidebar .filter-body .btn-apply-filter:hover {
  background: #3A7AB0;
  -webkit-box-shadow: 0 3px 6px rgba(0, 0, 0, 0.15);
          box-shadow: 0 3px 6px rgba(0, 0, 0, 0.15);
}

.badge.badge-purple {
  background: rgba(90, 68, 199, 0.15);
  color: #5A44C7;
}
.badge.badge-green {
  background: rgba(12, 194, 82, 0.15);
  color: #0cc252;
}
.badge.badge-gray {
  background: rgba(149, 165, 166, 0.15);
  color: #95A5A6;
}
.badge.badge-orange {
  background: rgba(230, 126, 34, 0.15);
  color: #E67E22;
}
.badge.badge-teal {
  background: rgba(32, 181, 170, 0.15);
  color: #20B5AA;
}
.badge.badge-blue {
  background: rgba(52, 152, 219, 0.15);
  color: #3498DB;
}
.badge.badge-indigo {
  background: rgba(51, 95, 240, 0.15);
  color: #335ff0;
}
.badge.badge-red {
  background: rgba(253, 109, 109, 0.15);
  color: #fd6d6d;
}
.badge.badge-yellow {
  background: rgba(255, 224, 51, 0.25);
  color: #cc9e00;
}
.badge.badge-pink {
  background: rgba(249, 103, 166, 0.15);
  color: #f967a6;
}

.map-marker {
  position: absolute;
  width: 50px;
  height: 50px;
  cursor: pointer;
  z-index: 50;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  -webkit-transition: -webkit-transform 0.2s;
  transition: -webkit-transform 0.2s;
  transition: transform 0.2s;
  transition: transform 0.2s, -webkit-transform 0.2s;
}
.map-marker:hover {
  -webkit-transform: translate(-50%, -50%) scale(1.1);
          transform: translate(-50%, -50%) scale(1.1);
}
.map-marker .marker-icon {
  position: relative;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-shadow: 0 4px 8px rgba(0, 0, 0, 0.25);
          box-shadow: 0 4px 8px rgba(0, 0, 0, 0.25);
  color: var(--color-w);
  font-size: var(--size_24);
}
.map-marker .marker-icon img {
  width: 50px;
  height: 50px;
}
.map-marker .marker-icon .marker-badge {
  position: absolute;
  top: -4px;
  right: -4px;
  background: var(--color-w);
  color: var(--text);
  width: 22px;
  height: 22px;
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-size: var(--size_12);
  font-weight: 600;
  -webkit-box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
          box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

.map-popup {
  position: absolute;
  z-index: 150;
  background: var(--color-w);
  border-radius: 16px;
  padding: var(--size_20);
  -webkit-box-shadow: 0 8px 30px rgba(0, 0, 0, 0.35) !important;
          box-shadow: 0 8px 30px rgba(0, 0, 0, 0.35) !important;
  min-width: 300px;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  margin-bottom: 8px;
}
.map-popup::before {
  position: absolute;
  left: 0;
  right: 0;
  bottom: -12px;
  margin: auto;
  width: 0;
  height: 0;
  content: "";
  border-style: solid;
  border-width: 20px 15px 0 15px;
  border-color: #ffffff transparent transparent transparent;
  -webkit-transform: rotate(0deg);
          transform: rotate(0deg);
}
.map-popup .popup-close {
  position: absolute;
  top: var(--size_12);
  right: var(--size_12);
}
.map-popup .popup-content {
  position: relative;
  min-width: 340px;
}
.map-popup .popup-content .popup-close-btn {
  position: absolute;
  top: -4px;
  right: -4px;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: none;
  background: #c2ccd3;
  color: #667085;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  cursor: pointer;
}
.map-popup .popup-content .badge {
  margin-bottom: var(--spacing-3);
  padding: 0.5rem 1.2rem;
  border-radius: 5px;
}
.map-popup .popup-content .popup-title {
  font-size: var(--size_16);
  font-weight: 600;
  margin-bottom: var(--size_20);
  line-height: 1.4;
  color: var(--text);
  padding-right: var(--size_40);
}
.map-popup .popup-content .btn-detail {
  width: 100%;
  background: var(--primary);
  color: var(--color-w);
  border: none;
  padding: 0.95rem var(--size_12);
  border-radius: 8px;
  font-size: var(--size_16);
  font-weight: 500;
  cursor: pointer;
}
.map-popup .popup-content .btn-detail:hover {
  background: var(--text);
  color: var(--color-w);
}
.cigarette-butt-box-cluster,
.custom-cluster-icon {
  background: transparent;
  border: none;
}
.CigaretteButtBox .marker-cluster,
.CigaretteButtBox .marker-cluster div {
  background: transparent;
  border: none;
  box-shadow: none;
}
.CigaretteButtBox .marker-cluster {
  width: 64px !important;
  height: 64px !important;
  margin-left: -32px !important;
  margin-top: -64px !important;
}
.CigaretteButtBox .marker-cluster div {
  width: auto !important;
  height: auto !important;
  margin: 0 !important;
  border-radius: 0 !important;
  overflow: visible !important;
  text-align: left !important;
}
.custom-cluster-icon {
  position: relative;
  width: 64px;
  height: 64px;
  overflow: visible;
}
.custom-cluster-icon img {
  width: 64px;
  height: 64px;
  display: block;
}
.custom-cluster-icon .cluster-count {
  position: absolute;
  top: 0;
  right: 0;
  min-width: 24px;
  height: 24px;
  padding: 0 6px;
  border-radius: 999px;
  background: #ffffff;
  color: #334155;
  font-size: 12px;
  font-weight: 700;
  line-height: 24px;
  text-align: center;
  box-shadow: 0 6px 14px rgba(15, 23, 42, 0.22);
  transform: translate(32%, -28%);
  z-index: 2;
}

.info-panel {
  position: absolute;
  top: 16px;
  right: -420px;
  width: 420px;
  height: calc(100% - 32px);
  background: hsla(0, 0%, 100%, 0.6);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  z-index: 300;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  -webkit-box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3) !important;
          box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3) !important;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  border-radius: 16px;
}
.info-panel.show {
  right: 16px;
}
.info-panel.show.collapsed {
  top: auto;
  bottom: 16px;
  right: 16px;
  height: auto;
}
.info-panel.show.collapsed .panel-body,
.info-panel.show.collapsed .panel-subheader,
.info-panel.show.collapsed .panel-footer {
  display: none;
}
.info-panel .panel-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: var(--spacing-2) var(--spacing-7);
  border-bottom: none;
  background: transparent;
  min-height: 56px;
  border-radius: 16px 16px 0 0;
}
.info-panel .panel-header .panel-title {
  font-size: var(--size_20);
  font-weight: 600;
  margin: 0;
  color: #333333;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.info-panel .panel-header .header-actions {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: var(--spacing-2);
}
.info-panel .panel-header.panel-header-detail {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: var(--spacing-3) var(--spacing-7);
  gap: var(--spacing-3);
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.info-panel .panel-header.panel-header-detail .btn-back {
  background: transparent;
  border: none;
  color: var(--primary);
  font-size: 14px;
  cursor: pointer;
  padding: var(--spacing-2) var(--spacing-3) 0 0;
  border-radius: var(--radius-sm);
  -webkit-transition: var(--transition-fast);
  transition: var(--transition-fast);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: var(--spacing-2);
  font-weight: 500;
  white-space: nowrap;
}
.info-panel .panel-header.panel-header-detail .btn-back i {
  font-size: 14px;
}
.info-panel .panel-header.panel-header-detail .btn-back:hover {
  background: var(--bg-hover);
}
.info-panel .panel-header.panel-header-detail .header-center {
  width: 100%;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.info-panel .panel-header.panel-header-detail .header-center .panel-title {
  font-size: 18px;
  font-weight: 600;
  margin: 0;
  color: #333333;
}
.info-panel .panel-header.panel-header-detail .header-center .panel-total-badge {
  background: #E8F4F8;
  padding: var(--spacing-2) var(--spacing-3);
  border-radius: 12px;
  font-size: 13px;
  color: #666666;
  white-space: nowrap;
}
.info-panel .panel-header.panel-header-detail .header-center .panel-total-badge strong {
  font-weight: 600;
  color: #333333;
}
.info-panel .panel-header.panel-header-detail .header-right {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: var(--spacing-3);
}
.info-panel .panel-header .btn-back {
  background: transparent;
  border: none;
  color: var(--primary);
  font-size: var(--body-sm);
  cursor: pointer;
  padding: var(--spacing-2) var(--spacing-3);
  border-radius: var(--radius-sm);
  -webkit-transition: var(--transition-fast);
  transition: var(--transition-fast);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: var(--spacing-2);
  font-weight: 500;
}
.info-panel .panel-header .btn-back i {
  font-size: var(--size_14);
}
.info-panel .panel-header .btn-back:hover {
  background: var(--surface-container);
}
.info-panel .panel-subheader {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: var(--spacing-3) var(--spacing-7);
  background: transparent;
  font-size: 13px;
  color: #666666;
  border-bottom: 1px solid #E0E0E0;
}
.info-panel .panel-subheader h3 {
  font-size: var(--heading-sm);
  font-weight: 600;
  margin: 0;
  color: #333333;
}
.info-panel .panel-subheader .panel-info {
  font-size: 13px;
  color: #666666;
}
.info-panel .panel-subheader .panel-info strong {
  font-weight: 600;
  color: #333333;
}
.info-panel .panel-subheader .panel-total {
  font-size: 13px;
  color: #666666;
}
.info-panel .panel-subheader .panel-total strong {
  font-weight: 600;
  color: #333333;
}
.info-panel .panel-body {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  overflow-y: auto;
  padding: var(--spacing-3) var(--spacing-7) var(--spacing-7);
}
.info-panel .panel-list-mode {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  height: 100%;
}
.info-panel .panel-detail-mode {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  height: 100%;
}
.info-panel .location-card {
  background: var(--white);
  border-radius: 12px;
  padding: var(--spacing-3);
  margin: 0 0 var(--spacing-3);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: var(--spacing-3);
  cursor: pointer;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
  -webkit-box-shadow: 0 1px 14px rgba(0, 0, 0, 0.14) !important;
          box-shadow: 0 1px 14px rgba(0, 0, 0, 0.14) !important;
  border: 0;
}
.info-panel .location-card:hover {
  -webkit-box-shadow: 0 2px 8px rgba(0, 0, 0, 0.12);
          box-shadow: 0 2px 8px rgba(0, 0, 0, 0.12);
  -webkit-transform: translateY(-1px);
          transform: translateY(-1px);
}
.info-panel .location-card .card-icon {
  width: 56px;
  height: 56px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  object-fit: contain;
}
.info-panel .location-card .card-content {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.info-panel .location-card .card-content .badge {
  margin-bottom: var(--spacing-2);
  border-radius: 5px;
  padding: 0.3rem 1rem;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
.info-panel .location-card .card-content .card-title {
  font-size: 14px;
  font-weight: 600;
  margin-bottom: var(--spacing-1);
  color: #333333;
  line-height: 1.4;
  overflow: visible;
  text-overflow: clip;
  white-space: normal;
}
.info-panel .location-card .card-content .card-meta {
  font-size: 12px;
  color: #666666;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: var(--spacing-1);
  margin-top: 0;
}
.info-panel .location-card .card-content .card-meta i {
  color: var(--text);
  font-size: var(--size_14);
  opacity: 0.4;
}
.info-panel .panel-footer {
  padding: var(--spacing-2);
  background: rgba(220, 220, 220, 0.7);
  border-top: none;
  border-radius: 0 0 16px 16px;
}
.info-panel .panel-footer .btn-more {
  width: 100%;
  background: transparent;
  color: var(--text);
  border: none;
  padding: var(--spacing-3) var(--spacing-4);
  border-radius: 8px;
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  -webkit-transition: all 0.2s;
  transition: all 0.2s;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: var(--spacing-2);
  -webkit-box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
          box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}
.info-panel .panel-footer .btn-more i {
  font-size: 12px;
}
.info-panel .panel-footer .btn-more:hover {
  background: #3A7AB0;
  -webkit-box-shadow: 0 3px 6px rgba(0, 0, 0, 0.15);
          box-shadow: 0 3px 6px rgba(0, 0, 0, 0.15);
  color: var(--color-w);
}
.info-panel .detail-card {
  background: var(--surface-container-lowest);
  border-radius: var(--radius-md);
  padding: var(--spacing-5);
  margin-bottom: var(--spacing-2);
  border: 1px solid var(--surface-container);
  -webkit-box-shadow: var(--shadow-ambient-sm);
          box-shadow: var(--shadow-ambient-sm);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: var(--spacing-4);
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}
.info-panel .detail-card .detail-icon {
  width: 64px;
  height: 64px;
  -ms-flex-negative: 0;
    flex-shrink: 0;
  -o-object-fit: contain;
     object-fit: contain;
}
.info-panel .detail-card .detail-content {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.info-panel .detail-card .detail-content .badge {
  margin-bottom: var(--spacing-3);
  display: inline-block;
  padding: 6px 10px;
  border-radius: 5px;
  font-size: var(--body-xs);
  font-weight: 500;
}
.info-panel .detail-card .detail-title {
  font-weight: 600;
  margin-bottom: var(--spacing-2);
  line-height: 1.5;
  color: var(--on-surface);
  font-size: var(--size_18);
}
.info-panel .detail-card .detail-location {
  font-size: var(--size_16);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: var(--spacing-2);
  margin: 0;
}
.info-panel .detail-card .detail-location i {
  color: var(--text);
  opacity: 0.5;
}
.info-panel .detail-fields {
  background: var(--color-w);
  border-radius: 12px;
  padding: var(--size_20);
  margin-bottom: var(--size_10);
  border: 1px solid var(--border-color);
}
.info-panel .detail-fields .detail-row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: var(--size_12) 0;
  border-bottom: 1px solid var(--border-color);
}
.info-panel .detail-fields .detail-row:last-child {
  border-bottom: none;
}
.info-panel .detail-fields .detail-row label {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 92px;
          flex: 0 0 92px;
  opacity: 0.7;
  margin: 0;
  font-size: 14px;
}
.info-panel .detail-fields .detail-row span {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  font-size: 15px;
  font-weight: 600;
  text-align: right;
}
.info-panel .coordinates-block {
  background: #ffffff;
  border-radius: 12px;
  padding: 1.8rem 1rem;
  margin-bottom: var(--spacing-2);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: var(--size_12);
  line-height: 1.5;
}
.info-panel .coordinates-block i {
  font-size: var(--size_20);
  color: #000000;
  width: 40px;
  height: 40px;
  background: #dbdbdb;
  border-radius: 30px;
  line-height: 40px;
  text-align: center;
}
.info-panel .coordinates-block span {
  font-size: var(--size_16);
  font-weight: 600;
}
.info-panel .btn-edit-action {
  width: 100%;
  background: #dfdcfc;
  border: 1px solid #5a49c4;
  font-size: var(--size_18);
  border-radius: 15px;
  color: #5a49c4;
  font-weight: bold;
  padding: 1rem 1rem;
}
.info-panel .btn-edit-action i {
  font-size: var(--size_18);
  color: #ffffff;
  width: 35px;
  height: 35px;
  background: #5a49c4;
  border-radius: 30px;
  line-height: 35px;
  text-align: center;
}

@media (max-width: 768px) {
  .CigaretteButtBox {
    height: calc(100vh - 100px);
  }
  .floating-search {
    top: var(--size_12);
    left: var(--size_12);
    right: var(--size_12);
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .floating-search .search-box {
    width: 100%;
  }
  .floating-search .btn-import-link {
    display: none;
  }
  .floating-search .search-buttons {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .floating-search .search-buttons .btn {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
  .filter-sidebar {
    width: 100%;
    max-width: 360px;
    left: -100%;
    top: 120px;
  }
  .filter-sidebar.show {
    left: 0;
    right: 0;
    margin: auto;
  }
  .info-panel {
    top: auto;
    bottom: -70%;
    right: 0;
    left: 0;
    width: 100%;
    height: 70%;
    border-radius: 24px 24px 0 0;
    -webkit-box-shadow: 0 -2px 20px rgba(0, 0, 0, 0.2);
            box-shadow: 0 -2px 20px rgba(0, 0, 0, 0.2);
    -webkit-transition: bottom 0.3s ease;
    transition: bottom 0.3s ease;
  }
  .info-panel.show {
    bottom: 0;
  }
  .info-panel .panel-header {
    border-radius: 24px 24px 0 0;
    position: relative;
  }
  .info-panel .panel-header::before {
    content: "";
    position: absolute;
    top: 8px;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    width: 40px;
    height: 4px;
    background: #d0d0d0;
    border-radius: 2px;
  }
  .map-marker {
    width: 40px;
    height: 40px;
  }
  .map-marker .marker-icon {
    width: 40px;
    height: 40px;
    font-size: var(--size_20);
  }
  .map-marker .marker-icon .marker-badge {
    top: -10px;
    right: -10px;
  }
}
