  .my-ip-checker-container * {
    margin: 0 !important;
    padding: 0 !important;
    box-sizing: border-box !important;
    font-family: 'Pretendard', -apple-system, BlinkMacSystemFont, system-ui, Roboto, 'Noto Sans KR', sans-serif !important;
  }

  .my-ip-checker-container {
    max-width: 1180px !important;
    margin: 20px auto !important;
    background: #FEFAE0 !important;
    border-radius: 12px !important;
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.1) !important;
    overflow: hidden !important;
    position: relative !important;
  }

  /* 헤더 영역 */
  .ip-header {
    background: #606C38 !important;
    padding: 20px 25px !important;
    color: #fff !important;
    position: relative !important;
  }

  .ip-header-content {
    flex-grow: 1 !important;
  }

  .ip-header h2 {
    font-size: 24px !important;
    font-weight: 700 !important;
    margin-bottom: 8px !important;
    display: flex !important;
    align-items: center !important;
    color: #FEFAE0 !important;
  }

  .ip-header h2 svg {
    margin-right: 10px !important;
  }

  .ip-header p {
    font-size: 15px !important;
    opacity: 0.9 !important;
    line-height: 1.4 !important;
    color: #FEFAE0 !important;
  }

  /* 메인 컨텐츠 영역 */
  .ip-content {
    display: flex !important;
    flex-direction: column !important;
    gap: 15px !important;
    padding: 20px !important;
  }

  .ip-row {
    width: 100% !important;
    display: flex !important;
    gap: 15px !important;
  }

  .main-row {
    flex-direction: column !important;
  }

  .info-row {
    flex-direction: row !important;
  }

  .button-row {
    flex-direction: row !important;
    justify-content: center !important;
  }

  /* 카드 스타일 */
  .ip-card {
    background: #FFFFFF !important;
    border-radius: 8px !important;
    padding: 18px !important;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.05) !important;
    transition: transform 0.3s ease, box-shadow 0.3s ease !important;
    position: relative !important;
    overflow: hidden !important;
    flex: 1 !important;
  }

  .ip-card:hover {
    transform: translateY(-3px) !important;
    box-shadow: 0 6px 15px rgba(0, 0, 0, 0.08) !important;
  }

  .ip-card h3 {
    font-size: 17px !important;
    font-weight: 600 !important;
    margin-bottom: 15px !important;
    color: #283618 !important;
    display: flex !important;
    align-items: center !important;
  }

  .ip-card h3 svg {
    margin-right: 8px !important;
    color: #606C38 !important;
  }

  .card-header {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    margin-bottom: 10px !important;
  }

  /* 메인 IP 표시 */
  .primary-card {
    background: #FFFFFF !important;
    padding: 20px !important;
  }

  .ip-address-container {
    position: relative !important;
    margin: 15px 0 20px !important;
  }

  .ip-main {
    font-size: 24px !important;
    font-weight: 700 !important;
    color: #283618 !important;
    letter-spacing: 0.5px !important;
    word-break: break-all !important;
    padding: 15px !important;
    background: rgba(96, 108, 56, 0.1) !important;
    border-radius: 8px !important;
    text-align: center !important;
    transition: filter 0.3s ease !important;
    min-height: 64px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
  }

  .ip-type {
    background: #606C38 !important;
    color: white !important;
    font-size: 13px !important;
    padding: 4px 10px !important;
    border-radius: 12px !important;
    font-weight: 500 !important;
  }

  .ip-visibility-toggle {
    position: absolute !important;
    right: 10px !important;
    bottom: 10px !important;
    background: none !important;
    border: none !important;
    cursor: pointer !important;
    padding: 5px !important;
    color: #606C38 !important;
    opacity: 0.7 !important;
    transition: all 0.3s ease !important;
    outline: none !important;
  }

  .ip-visibility-toggle:hover {
    opacity: 1 !important;
    transform: scale(1.1) !important;
  }

  .ip-blurred {
    filter: blur(8px) !important;
  }

  /* 버튼 그룹 */
  .ip-button-group {
    display: flex !important;
    gap: 15px !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    width: 100% !important;
    max-width: 600px !important;
    margin: 0 auto !important;
  }

  .ip-button {
    flex: 1 !important;
    min-width: 200px !important;
    padding: 14px 20px !important;
    font-size: 16px !important;
    font-weight: 500 !important;
    border: none !important;
    border-radius: 6px !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    outline: none !important;
  }

  .ip-button.primary {
    color: #FEFAE0 !important;
    background: #606C38 !important;
  }

  .ip-button.secondary {
    color: #FEFAE0 !important;
    background: #DDA15E !important;
  }

  .ip-button:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15) !important;
  }

  .ip-button.primary:hover {
    background: #4a5429 !important;
  }

  .ip-button.secondary:hover {
    background: #BC6C25 !important;
  }

  .ip-button:active {
    transform: translateY(0) !important;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1) !important;
  }

  .ip-button svg {
    margin-right: 8px !important;
  }

  /* 보안 상태 */
  .security-card {
    background: #FFFFFF !important;
  }

  .security-status {
    display: flex !important;
    align-items: center !important;
    padding: 10px 12px !important;
    background: rgba(96, 108, 56, 0.1) !important;
    border-radius: 6px !important;
    margin-bottom: 15px !important;
  }

  .security-icon {
    margin-right: 12px !important;
    flex-shrink: 0 !important;
  }

  .security-details {
    flex-grow: 1 !important;
    min-width: 0 !important;
  }

  .security-message {
    font-weight: 600 !important;
    color: #283618 !important;
    margin-bottom: 3px !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }

  .security-description {
    font-size: 13px !important;
    color: #606C38 !important;
    line-height: 1.4 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }

  /* 디바이스 정보 */
  .device-info {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }

  .device-info-item {
    background: rgba(221, 161, 94, 0.1) !important;
    padding: 10px !important;
    border-radius: 6px !important;
  }

  .device-info-label {
    font-size: 13px !important;
    color: #606C38 !important;
    margin-bottom: 5px !important;
    display: flex !important;
    align-items: center !important;
  }

  .device-info-label svg {
    margin-right: 5px !important;
    flex-shrink: 0 !important;
  }

  .device-info-value {
    font-weight: 600 !important;
    color: #283618 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }

  /* 위치 정보 */
    .location-card, .network-card {
      background: #FFFFFF !important;
    }

    .location-grid, .network-grid {
      display: flex !important;
      flex-direction: column !important;
      gap: 6px !important;
      max-height: none !important;
      overflow-y: visible !important;
    }

    .location-item, .network-item {
      background: rgba(96, 108, 56, 0.05) !important;
      padding: 6px 8px !important;
      border-radius: 6px !important;
    }

    .location-label, .network-label {
      font-size: 12px !important;
      color: #606C38 !important;
      margin-bottom: 3px !important;
      font-weight: 500 !important;
    }

    .location-value, .network-value {
      font-size: 16px !important;
      font-weight: 600 !important;
      color: #283618 !important;
      white-space: nowrap !important;
      overflow: hidden !important;
      text-overflow: ellipsis !important;
    }

  /* 스낵바 알림 */
  .snackbar {
    visibility: hidden !important;
    min-width: 250px !important;
    margin-left: -125px !important;
    background-color: #283618 !important;
    color: #FEFAE0 !important;
    text-align: center !important;
    border-radius: 4px !important;
    padding: 12px !important;
    position: fixed !important;
    z-index: 1001 !important;
    left: 50% !important;
    bottom: 30px !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
  }

  .snackbar.show {
    visibility: visible !important;
    animation: fadein 0.5s, fadeout 0.5s 2.5s !important;
  }

  @keyframes fadein {
    from {bottom: 0 !important; opacity: 0 !important;}
    to {bottom: 30px !important; opacity: 1 !important;}
  }

  @keyframes fadeout {
    from {bottom: 30px !important; opacity: 1 !important;}
    to {bottom: 0 !important; opacity: 0 !important;}
  }

  /* 로딩 애니메이션 */
  .loading-dot {
    display: inline-block !important;
    width: 8px !important;
    height: 8px !important;
    border-radius: 50% !important;
    margin: 0 3px !important;
    background: rgba(96, 108, 56, 0.3) !important;
    animation: loadingDot 1.4s infinite ease-in-out both !important;
  }

  .loading-dot:nth-child(1) {
    animation-delay: -0.32s !important;
  }

  .loading-dot:nth-child(2) {
    animation-delay: -0.16s !important;
  }

  @keyframes loadingDot {
    0%, 80%, 100% { transform: scale(0) !important; }
    40% { transform: scale(1.0) !important; }
  }

  .loading-text {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
  }

  /* 오류 메시지 스타일 */
  .error-message {
    color: #BC6C25 !important;
    padding: 8px !important;
    border: 1px solid rgba(188, 108, 37, 0.2) !important;
    border-radius: 4px !important;
    background: rgba(188, 108, 37, 0.1) !important;
    margin: 10px 0 !important;
    display: flex !important;
    align-items: center !important;
    font-size: 14px !important;
  }

  .error-message svg {
    margin-right: 8px !important;
    flex-shrink: 0 !important;
  }

  /* 모바일 반응형 */
  @media (max-width: 768px) {
    .info-row {
      flex-direction: column !important;
    }
    
    .ip-main {
      font-size: 20px !important;
      min-height: 60px !important;
    }
    
    .ip-header h2 {
      font-size: 22px !important;
    }
    
    .ip-button-group {
      flex-direction: column !important;
    }
    
    .ip-button {
      width: 100% !important;
    }
  }

  /* 작은 모바일 화면 최적화 */
  @media (max-width: 480px) {
    .ip-header {
      padding: 18px !important;
    }
    
    .ip-main {
      font-size: 18px !important;
      padding: 12px 8px !important;
    }
    
    .ip-content {
      padding: 15px 12px !important;
      gap: 12px !important;
    }
    
    .ip-card {
      padding: 15px !important;
    }
    
    .ip-button {
      font-size: 14px !important;
      padding: 12px 16px !important;
    }
  }