  /* Yekan Bakh Font Family Configuration */
  @font-face {
      font-family: 'YekanBakh';
      src: url('/font/yekanbakh/YekanBakh-Thin.ttf') format('truetype');
      font-weight: 100;
      font-style: normal;
  }

  @font-face {
      font-family: 'YekanBakh';
      src: url('/font/yekanbakh/YekanBakh-Light.ttf') format('truetype');
      font-weight: 300;
      font-style: normal;
  }

  @font-face {
      font-family: 'YekanBakh';
      src: url('/font/yekanbakh/YekanBakh-Regular_0.ttf') format('truetype');
      font-weight: 400;
      font-style: normal;
  }

  @font-face {
      font-family: 'YekanBakh';
      src: url('/font/yekanbakh/yekan bakh en 05 medium.ttf') format('truetype');
      font-weight: 500;
      font-style: normal;
  }

  @font-face {
      font-family: 'YekanBakh';
      src: url('/font/yekanbakh/YekanBakh-SemiBold.ttf') format('truetype');
      font-weight: 600;
      font-style: normal;
  }

  @font-face {
      font-family: 'YekanBakh';
      src: url('/font/yekanbakh/YekanBakh-Bold.ttf') format('truetype');
      font-weight: 700;
      font-style: normal;
  }

  @font-face {
      font-family: 'YekanBakh';
      src: url('/font/yekanbakh/YekanBakh-ExtraBold.ttf') format('truetype');
      font-weight: 800;
      font-style: normal;
  }

  @font-face {
      font-family: 'YekanBakh';
      src: url('/font/yekanbakh/YekanBakh-Black.ttf') format('truetype');
      font-weight: 900;
      font-style: normal;
  }

  :root {
      --color-primary: #223f99;
      --color-primary-light: #3d5bc4;
      --color-primary-dark: #0a1636;

      --color-secondary: #a7a9ac;
      --color-secondary-light: #c5c7ca;
      --color-secondary-dark: #7e8083;

      --color-white: #ffffff;
      --color-black: #000000;

      --color-gray-100: #f5f6f7;
      --color-gray-200: #e5e7eb;
      --color-gray-300: #d1d5db;
      --color-gray-400: #9ca3af;
      --color-gray-500: #6b7280;
      --color-gray-700: #374151;
      --color-gray-900: #111827;

      --color-bg-body: #ffffff;
      --color-bg-surface: #f5f6f7;
      --color-bg-muted: #e5e7eb;
      --color-bg-inverse: #111827;

      --color-bg-primary: var(--color-primary);
      --color-bg-secondary: var(--color-secondary);

      --color-text-main: #111827;
      --color-text-muted: #6b7280;
      --color-text-light: #9ca3af;
      --color-text-inverse: #ffffff;

      --color-text-primary: var(--color-primary);
      --color-text-secondary: var(--color-secondary);

      --color-link: var(--color-primary);
      --color-link-hover: var(--color-primary-light);
      --color-link-active: var(--color-primary-dark);
      --color-link-visited: #5a4fcf;

      --color-border: #e5e7eb;
      --color-border-light: #f1f3f5;
      --color-border-strong: #d1d5db;

      --color-border-focus: var(--color-primary);
      --color-border-input: #d1d5db;

      --color-btn-primary-bg: var(--color-primary);
      --color-btn-primary-text: #ffffff;
      --color-btn-primary-hover: var(--color-primary-light);
      --color-btn-primary-active: var(--color-primary-dark);

      --color-btn-secondary-bg: var(--color-secondary);
      --color-btn-secondary-text: #ffffff;
      --color-btn-secondary-hover: var(--color-secondary-light);

      --color-input-bg: #ffffff;
      --color-input-text: #111827;
      --color-input-placeholder: #9ca3af;
      --color-input-border: #d1d5db;
      --color-input-focus: var(--color-primary);

      --color-success: #16a34a;
      --color-success-bg: #dcfce7;

      --color-warning: #f59e0b;
      --color-warning-bg: #fef3c7;

      --color-danger: #dc2626;
      --color-danger-bg: #fee2e2;

      --color-info: #0284c7;
      --color-info-bg: #e0f2fe;

      --color-selection-bg: var(--color-primary-light);
      --color-selection-text: #ffffff;

      --color-shadow: rgba(0, 0, 0, 0.15);
  }

  * {
      font-family: 'YekanBakh', sans-serif;
      box-sizing: border-box;
      margin: 0;
      padding: 0;
  }

  ::selection {
      background: var(--color-selection-bg);
      color: var(--color-selection-text);
  }

  body {
      background:
          radial-gradient(circle at top right, rgba(61, 91, 196, 0.08), transparent 30%),
          radial-gradient(circle at bottom left, rgba(34, 63, 153, 0.08), transparent 28%),
          linear-gradient(180deg, #f8faff 0%, #eef3fb 100%);
      color: var(--color-text-main);
      min-height: 100vh;
      padding: 32px 16px;
  }

  .page-wrap {
      max-width: 1180px;
      margin: 0 auto;
  }

  .card {
      background: rgba(255, 255, 255, 0.94);
      border: 1px solid rgba(229, 231, 235, 0.9);
      box-shadow:
          0 20px 60px rgba(34, 63, 153, 0.08),
          0 8px 24px rgba(17, 24, 39, 0.06);
      border-radius: 24px;
      overflow: hidden;
      backdrop-filter: blur(8px);
  }

  .card-header {
      background: linear-gradient(135deg, var(--color-primary-dark), var(--color-primary));
      color: var(--color-text-inverse);
      padding: 28px 28px 22px;
      position: relative;
  }

  .card-header::after {
      content: "";
      position: absolute;
      inset: 0;
      background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.06), transparent);
      pointer-events: none;
  }

  .card-header h1 {
      font-size: 28px;
      font-weight: 800;
      margin-bottom: 8px;
  }

  .card-header p {
      font-size: 14px;
      color: rgba(255, 255, 255, 0.82);
      line-height: 1.9;
  }

  .card-body {
      padding: 28px;
  }

  .form-layout {
      display: grid;
      grid-template-columns: 1.05fr 1fr;
      gap: 24px;
      align-items: start;
  }

  .panel {
      background: var(--color-white);
      border: 1px solid var(--color-border);
      border-radius: 20px;
      padding: 20px;
      box-shadow: 0 8px 24px rgba(17, 24, 39, 0.04);
  }

  .panel-title {
      display: flex;
      align-items: center;
      gap: 10px;
      margin-bottom: 18px;
  }

  .panel-badge {
      width: 38px;
      height: 38px;
      border-radius: 12px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      background: linear-gradient(135deg, var(--color-primary), var(--color-primary-light));
      color: var(--color-white);
      font-size: 18px;
      box-shadow: 0 8px 20px rgba(34, 63, 153, 0.22);
  }

  .panel-title h2 {
      font-size: 18px;
      font-weight: 800;
      color: var(--color-text-primary);
  }

  .panel-title small {
      display: block;
      color: var(--color-text-muted);
      margin-top: 2px;
      font-size: 12px;
  }

  .form-grid {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 16px;
  }

  .field {
      display: flex;
      flex-direction: column;
      gap: 8px;
  }

  .field.full {
      grid-column: 1 / -1;
  }

  .field label {
      font-size: 13px;
      font-weight: 700;
      color: var(--color-text-main);
  }

  .input,
  .select,
  .textarea {
      width: 100%;
      border: 1px solid var(--color-input-border);
      background: var(--color-input-bg);
      color: var(--color-input-text);
      border-radius: 14px;
      padding: 14px 15px;
      font-size: 14px;
      outline: none;
      transition: 0.22s ease;
      box-shadow: 0 2px 0 rgba(255, 255, 255, 0.6) inset;
  }

  .input::placeholder,
  .textarea::placeholder {
      color: var(--color-input-placeholder);
  }

  .input:focus,
  .select:focus,
  .textarea:focus {
      border-color: var(--color-input-focus);
      box-shadow:
          0 0 0 4px rgba(34, 63, 153, 0.10),
          0 8px 18px rgba(34, 63, 153, 0.08);
  }

  .textarea {
      min-height: 88px;
      resize: vertical;
      line-height: 1.9;
  }

  .hint {
      font-size: 12px;
      color: var(--color-text-muted);
      line-height: 1.8;
  }

  .map-box {
      border: 1px solid var(--color-border);
      border-radius: 18px;
      overflow: hidden;
      background: var(--color-bg-surface);
      box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.6);
  }

  #adMap {
      width: 100%;
      height: 420px;
  }

  .location-summary {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 12px;
      margin-top: 14px;
  }

  .mini-box {
      background: linear-gradient(180deg, #fbfcff 0%, #f5f8fe 100%);
      border: 1px solid var(--color-border);
      border-radius: 14px;
      padding: 12px 14px;
  }

  .mini-box span {
      display: block;
      font-size: 11px;
      color: var(--color-text-muted);
      margin-bottom: 5px;
  }

  .mini-box strong {
      display: block;
      font-size: 13px;
      color: var(--color-text-main);
      word-break: break-word;
      line-height: 1.8;
  }

  .actions {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 16px;
      margin-top: 24px;
      flex-wrap: wrap;
  }

  .submit-btn {
      border: none;
      outline: none;
      cursor: pointer;
      border-radius: 16px;
      background: linear-gradient(135deg, var(--color-btn-primary-bg), var(--color-btn-primary-hover));
      color: var(--color-btn-primary-text);
      font-size: 15px;
      font-weight: 800;
      padding: 14px 24px;
      min-width: 180px;
      transition: 0.25s ease;
      box-shadow: 0 14px 26px rgba(34, 63, 153, 0.24);
  }

  .submit-btn:hover {
      transform: translateY(-1px);
      box-shadow: 0 18px 32px rgba(34, 63, 153, 0.28);
  }

  .submit-btn:active {
      transform: translateY(0);
  }

  .submit-btn:disabled {
      opacity: 0.7;
      cursor: not-allowed;
      transform: none;
      box-shadow: none;
  }

  .result-box {
      flex: 1;
      min-height: 54px;
      border-radius: 16px;
      padding: 14px 16px;
      display: none;
      align-items: center;
      line-height: 1.9;
      font-size: 14px;
      font-weight: 600;
      border: 1px solid transparent;
  }

  .result-box.show {
      display: flex;
  }

  .result-box.success {
      background: var(--color-success-bg);
      color: var(--color-success);
      border-color: rgba(22, 163, 74, 0.18);
  }

  .result-box.error {
      background: var(--color-danger-bg);
      color: var(--color-danger);
      border-color: rgba(220, 38, 38, 0.18);
  }

  .result-box.info {
      background: var(--color-info-bg);
      color: var(--color-info);
      border-color: rgba(2, 132, 199, 0.18);
  }

  .field-loading {
      background-image: linear-gradient(90deg, rgba(34, 63, 153, 0.03), rgba(34, 63, 153, 0.08), rgba(34, 63, 153, 0.03));
      background-size: 200% 100%;
      animation: shimmer 1.1s linear infinite;
  }

  .field-updated {
      border-color: var(--color-success) !important;
      box-shadow: 0 0 0 4px rgba(22, 163, 74, 0.10) !important;
  }

  @keyframes shimmer {
      0% {
          background-position: 200% 0;
      }

      100% {
          background-position: -200% 0;
      }
  }

  .leaflet-container {
      font: inherit;
  }

  @media (max-width: 992px) {
      .form-layout {
          grid-template-columns: 1fr;
      }

      #adMap {
          height: 360px;
      }
  }

  @media (max-width: 640px) {
      body {
          padding: 18px 10px;
      }

      .card-header,
      .card-body {
          padding: 18px;
      }

      .panel {
          padding: 16px;
      }

      .form-grid,
      .location-summary {
          grid-template-columns: 1fr;
      }

      .actions {
          flex-direction: column-reverse;
          align-items: stretch;
      }

      .submit-btn {
          width: 100%;
      }
  }



  .map-box {
      position: relative;
  }

  .locate-btn {
      position: absolute;
      right: 14px;
      bottom: 14px;
      z-index: 1000;
      width: 52px;
      height: 52px;
      border: none;
      border-radius: 16px;
      background: rgba(255, 255, 255, 0.96);
      color: var(--color-primary);
      box-shadow:
          0 10px 24px rgba(17, 24, 39, 0.16),
          0 2px 8px rgba(17, 24, 39, 0.08);
      display: inline-flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      transition: 0.2s ease;
      backdrop-filter: blur(8px);
  }

  .locate-btn:hover {
      transform: translateY(-1px);
      background: #ffffff;
      box-shadow:
          0 14px 28px rgba(17, 24, 39, 0.18),
          0 4px 12px rgba(17, 24, 39, 0.10);
  }

  .locate-btn:active {
      transform: translateY(0);
  }

  .locate-btn:disabled {
      cursor: wait;
      opacity: 0.7;
  }

  .locate-btn i,
  .locate-btn svg {
      width: 22px;
      height: 22px;
  }

  @media (max-width: 640px) {
      .locate-btn {
          right: 10px;
          bottom: 10px;
          width: 48px;
          height: 48px;
          border-radius: 14px;
      }
  }

  .del-btn {
      background: linear-gradient(135deg, var(--color-info), var(--color-btn-primary-hover));
      color: var(--color-btn-primary-text);
  }










  .property-grid {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
      gap: 10px;
      margin-bottom: 20px;
  }

  .prop-card {
      padding: 15px 10px;
      border: 2px solid #e5e7eb;
      border-radius: 12px;
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 8px;
      cursor: pointer;
      transition: all 0.3s ease;
      color: #9ca3af;
      background: #f9fafb;
  }

  .prop-card.active {
      border-color: var(--c);
      color: var(--c);
      background: color-mix(in srgb, var(--c), transparent 90%);
      box-shadow: 0 8px 16px -4px color-mix(in srgb, var(--c), transparent 70%);
      transform: translateY(-2px);
  }