﻿      background-image: linear-gradient(rgba(30, 58, 95, .05) 1px, transparent 1px), linear-gradient(90deg, rgba(30, 58, 95, .05) 1px, transparent 1px);
      background-size: 50px 50px;
      pointer-events: none
    }

    .login-glow {
      position: fixed;
      width: 700px;
      height: 700px;
      border-radius: 50%;
      background: radial-gradient(circle, rgba(30, 58, 95, .07) 0%, transparent 70%);
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      pointer-events: none
    }

    .login-card {
      position: relative;
      z-index: 10;
      width: 440px;
      max-width: 100%;
      background: var(--surface);
      border: 1px solid var(--border);
      border-radius: 14px;
      padding: 44px;
      box-shadow: 0 4px 24px rgba(30, 58, 95, .1), 0 1px 3px rgba(0, 0, 0, .06);
      margin: auto
    }

    .login-brand {
      display: flex;
      align-items: center;
      gap: 14px;
      margin-bottom: 36px
    }

    .login-logo {
      width: 64px;
      height: 64px;
      background: linear-gradient(180deg, #f8fbff 0%, #eef4fb 100%);
      border: 1px solid rgba(30, 58, 95, .12);
      border-radius: 12px;
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 10px;
      box-shadow: inset 0 1px 0 rgba(255, 255, 255, .8), 0 8px 18px rgba(30, 58, 95, .08);
      flex-shrink: 0
    }

    .login-logo img {
      width: 100%;
      height: 100%;
      object-fit: contain;
      display: block
    }

    .login-title {
      font-size: 22px;
      font-weight: 800;
      color: var(--navy);
      letter-spacing: -.5px;
      line-height: 1.1
    }

    .login-subtitle {
      font-size: 11px;
      color: var(--text-muted);
      font-family: var(--mono);
      letter-spacing: .35px;
      margin-top: 3px
    }

    .login-tagline {
      font-size: 12px;
      color: var(--text-muted);
      margin-bottom: 28px;
      padding-bottom: 28px;
      border-bottom: 1px solid var(--border);
      line-height: 1.6
    }

    .login-area-badge {
      display: block;
      font-size: 10px;
      font-family: var(--mono);
      letter-spacing: .6px;
      text-transform: uppercase;
      color: var(--navy);
      background: rgba(30,58,95,.07);
      border: 1px solid rgba(30,58,95,.15);
      border-radius: 4px;
      padding: 3px 8px;
      margin-bottom: 8px;
      width: fit-content
    }

    .form-group {
      margin-bottom: 18px
    }

    .form-label {
      display: block;
      font-size: 12px;
      font-weight: 600;
      color: var(--text-dim);
      margin-bottom: 6px;
      letter-spacing: .3px;
      text-transform: uppercase
    }

    .form-input {
      width: 100%;
      padding: 10px 14px;
      border: 1px solid var(--border2);
      border-radius: var(--r);
      font-size: 14px;
      font-family: var(--sans);
      color: var(--text);
      background: var(--surface2);
      transition: border-color .15s, box-shadow .15s
    }

    .form-input:focus {
      border-color: var(--navy);
      box-shadow: 0 0 0 3px rgba(30, 58, 95, .1);
      background: var(--surface)
    }

    select.form-input {
      cursor: pointer
    }

    .dampak-checkbox-group {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 6px;
      padding: 8px;
      border: 1px solid #e2e8f0;
      border-radius: 8px;
      background: #fff;
    }
    .dampak-cb-item {
      display: flex;
      align-items: center;
      gap: 10px;
      font-size: 14px;
      color: #374151;
      cursor: pointer;
      user-select: none;
      padding: 10px 12px;
      border-radius: 6px;
      border: 1px solid #e2e8f0;
      background: #f8fafc;
      transition: background 0.15s, border-color 0.15s;
      min-height: 44px;
    }
    .dampak-cb-item:has(input:checked) {
      background: #eff6ff;
      border-color: #93c5fd;
      color: #1d4ed8;
      font-weight: 500;
    }
    .dampak-cb-item input[type="checkbox"] {
      width: 18px;
      height: 18px;
      accent-color: #2563eb;
      cursor: pointer;
      flex-shrink: 0;
    }

    textarea.form-input {
      resize: vertical;
      min-height: 80px
    }

    .file-upload-input {
      position: absolute;
      width: 1px;
